这个作业属于哪个课程 | https://edu.cnblogs.com/campus/fzzcxy/FZUZCSDN202201 |
这个作业要求在哪里 | https://edu.cnblogs.com/campus/fzzcxy/FZUZCSDN202201/homework/12704 |
这个作业的目标 | 能够使用源码安装Mininet 能够使用Mininet的可视化工具生成拓扑 能够使用Mininet的命令行生成特定拓扑 能够使用Mininet交互界面管理SDN拓扑 能够使用Python脚本构建SDN拓扑。 |
2.使用Mininet的命令行生成如下拓扑:
a) 3台交换机,每个交换机连接1台主机,3台交换机连接成一条线。
b) 3台主机,每个主机都连接到同1台交换机上。
3.在2 b)的基础上,在Mininet交互界面上新增1台主机并且连接到交换机上,再测试新拓扑的连通性。
4.编辑基本要求第1步保存的Python脚本,添加如下网络性能限制,生成拓扑:
a) h1的cpu最高不超过50%;
h1 = net.addHost('h1', cls=Host, ip='10.0.0.1', defaultRoute=None, cpu=0.5)
b) h1和s1之间的链路带宽为10,延迟为5ms,最大队列大小为1000,损耗率50。
net.addLink(s1, h1, bw=10, delay='5ms', max_queue_size=1000, loss=50, use_htb=True)
(二)进阶要求
编写Python脚本,生成如下数据中心网络拓扑,要求:
编写.py拓扑文件,命名为“学号_fattree.py”;
必须通过Mininet的custom参数载入上述文件,不得直接使用miniedit.py生成的.py文件;
设备名称必须和下图一致;
使用Python的循环功能实现,不得在代码中手工直接添加设备和链路。
#!/usr/bin/python
#创建网络拓扑
"""Custom topology example
Adding the 'topos' dict with a key/value pair to generate our newly defined
topology enables one to pass in '--topo=mytopo' from the command line.
"""
from mininet.topo import Topo
from mininet.net import Mininet
from mininet.node import RemoteController,CPULimitedHost
from mininet.link import TCLink
from mininet.util import dumpNodeConnections
class MyTopo( Topo ):
"Simple topology example."
def __init__( self ):
"Create custom topo."
# Initialize topology
Topo.__init__( self )
L1 = 2
L2 = L1 * 2
L3 = L2 * 2
s = []
# add core ovs
for i in range( L1 + L2 + L3 ):
sw = self.addSwitch( 's{}'.format( i + 1 ) )
s.append( sw )
# add links between core and aggregation ovs
t = L1
for i in range( L1 ):
sw1 = s[i]
for sw2 in s[t:t+4]:
# self.addLink(sw2, sw1, bw=10, delay='5ms', loss=10, max_queue_size=1000, use_htb=True)
self.addLink( sw2, sw1 )
t = L1 + L2
# add links between aggregation and edge ovs
for i in range( L1, L1+ L2, 2 ):
if i > (L1 + L2) / 2:
t+=4
for sw1 in s[i:i+2]:
for sw2 in s[t:t+4]:
self.addLink( sw2, sw1 )
#add hosts and its links with edge ovs
count = 1
for sw1 in s[L1+L2:]:
for i in range(2):
host = self.addHost( 'h{}'.format( count ))
self.addLink( sw1, host )
count += 1
topos = { 'mytopo': ( lambda: MyTopo() ) }
总结
实验难度适中,基础要求部分看着pdf操作即可,进阶部分比较具有挑战性(虽然只会改不会自己写)
遇到的困难
1.执行sudo ./mininet/examples/miniedit.py
时报错
Traceback (most recent call last):
File "./mininet/examples/miniedit.py", line 27, in <module>
from mininet.log import info, debug, warn, setLogLevel
ImportError: No module named mininet.log
解决方法:修改python软链接
sudo rm -rf /usr/bin/python3
sudo rm -rf /usr/bin/python
sudo ln -s /usr/bin/python3.8 /usr/bin/python3
sudo ln -s /usr/bin/python3.8 /usr/bin/python
2.基础要求 3 添加完主机后,新添加的主机与其它主机直接无法连通
解决方法:
py s1.attach('s1-eth4') #添加/打开交换机s1上的接口eth4
py h4,setIP('10.0.0.4') #给h3设置ip地址,
3.基础要求 4 修改 1 所保存的学号.py文件时,该文件是只读文件无法修改保存
解决方法:
(1)强制保存退出:wq!
(2)用sudo权限编辑sudo vim ./学号.py
(3)给文件添加写权限chmod +w 学号.py