实验1:SDN拓扑实践
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.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 )
s = []
h = []
# add switch
for i in range( 14 ):
sw = self.addSwitch( 's{}'.format( i + 1 ) )
s.append( sw )
# add host
for i in range( 16 ):
ho = self.addHost( 'h{}'.format( i + 1 ) )
h.append( ho )
# add links between core and aggregation ovs
for i in range( 2 ):
for j in range( 2, 6 ):
self.addLink( s[j], s[i] )
# add links between aggregation and edge ovs
for i in range( 2, 5, 2 ):
for j in range( i, i+2 ):
for k in range( 2*i+2, 2*i+6 ):
self.addLink( s[k], s[j] )
# links hosts with edge ovs
count = 0
for i in range( 6, 14 ):
for j in range( 2 ):
self.addLink( h[j+count], s[i] )
count += 2
topos = { 'mytopo': ( lambda: MyTopo() ) }
个人总结
1.重装了mininet,安装组件过程中无法多次访问github,尝试vpn和修改host无果,最后分布骤安装了各组件和依赖。
2.py文件只读,用"sudo chmod 777 *.py"修改文件读写权限。
3.做进阶实验之前,几乎没接触过python,所以去学习了python的基础,然后结合老师所给的python代码,并上网查看相关资料,最后通过几个循环来生成了目的结果。