(一)基本要求
1.使用Mininet可视化工具,生成下图所示的拓扑,并保存拓扑文件名为学号.py。
2.使用Mininet的命令行生成如下拓扑:
a) 3台交换机,每个交换机连接1台主机,3台交换机连接成一条线。
b) 3台主机,每个主机都连接到同1台交换机上。
3.在2 b)的基础上,在Mininet交互界面上新增1台主机并且连接到交换机上,再测试新拓扑的连通性。
4.编辑基本要求第1步保存的Python脚本,添加如下网络性能限制,生成拓扑:
a) h1的cpu最高不超过50%;
b) h1和s1之间的链路带宽为10,延迟为5ms,最大队列大小为1000,损耗率50。
(二)进阶要求
编写Python脚本,生成如下数据中心网络拓扑,要求:
编写.py拓扑文件,命名为“学号_fattree.py”;
必须通过Mininet的custom参数载入上述文件,不得直接使用miniedit.py生成的.py文件;
设备名称必须和下图一致;
使用Python的循环功能实现,不得在代码中手工直接添加设备和链路。
#!/usr/bin/python
from mininet.net import Mininet
from mininet.topo import Topo
from mininet.node import RemoteController,CPULimitedHost
from mininet.link import TCLink
from mininet.util import dumpNodeConnections
class MyTopo(Topo):
def __init__(self):
# initialize topology
Topo.__init__(self)
L1 = 2
L2 = L1 * 2
L3 = L2 * 2
c = []
a = []
e = []
# add ovs 添加交换机
for i in range(L1):
#fotmat作为Python的的格式字符串函数,主要通过字符串中的花括号{},来识别替换字段,从而完成字符串的格式化。
sw = self.addSwitch('s{}'.format(i + 1))
c.append(sw)
for i in range(L2):
sw = self.addSwitch('s{}'.format(L1 + i + 1))
a.append(sw)
for i in range(L3):
sw = self.addSwitch('s{}'.format(L1 + L2 + i + 1))
e.append(sw)
# add links c-a a-e 连接交换机之间链路
for i in range(L1):
sw1 = c[i]
for sw2 in a[i // 2::L1 // 2]:
# a[开始::步长]
self.addLink(sw2, sw1)
for i in range(0, L2, 2):
for sw1 in a[i:i + 2]:
# a[开始下标:终止下标-1]
j = i + i
for sw2 in e[j:j + 4]:
self.addLink(sw2, sw1)
# add links hosts-e 添加主机并连接主机和交换机
count = 1
for sw1 in e:
for i in range(2):
host = self.addHost('h{}'.format(count))
self.addLink(sw1, host)
count += 1
topos = { 'mytopo': ( lambda: MyTopo() ) }
总结:
1.实验基础部分跟着老师的课件就可以掌握了,进阶部分比较难,在这个过程中也遇到了一些没有见过的问题,在遇到问题时,自己通过查资料或者询问同学来解决问题
2.当重复构建了相同的拓扑,可以使用mn -c消除旧的拓扑