(一)基本要求
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。
修改后的代码:
#!/usr/bin/env python
from mininet.net import Mininet
from mininet.node import Controller, RemoteController, OVSController
from mininet.node import CPULimitedHost, Host, Node
from mininet.node import OVSKernelSwitch, UserSwitch
from mininet.node import IVSSwitch
from mininet.cli import CLI
from mininet.log import setLogLevel, info
from mininet.link import TCLink, Intf
from subprocess import call
def myNetwork():
net = Mininet( topo=None,
build=False,
ipBase='10.0.0.0/8')
info( '*** Adding controller\n' )
c0=net.addController(name='c0',
controller=Controller,
protocol='tcp',
port=6633)
info( '*** Add switches\n')
s1 = net.addSwitch('s1', cls=OVSKernelSwitch)
s2 = net.addSwitch('s2', cls=OVSKernelSwitch)
info( '*** Add hosts\n')
h1 = net.addHost('h1', cls=Host, ip='10.0.0.1', defaultRoute=None,cpu=0.5)
h2 = net.addHost('h2', cls=Host, ip='10.0.0.2', defaultRoute=None)
h3 = net.addHost('h3', cls=Host, ip='10.0.0.3', defaultRoute=None)
h4 = net.addHost('h4', cls=Host, ip='10.0.0.4', defaultRoute=None)
info( '*** Add links\n')
net.addLink(s2, s1)
net.addLink(s1, h1, bw=10, delay='5ms',max_queue_size=1000, loss=10, use_htb=True)
net.addLink(s1, h2)
net.addLink(s2, h4)
net.addLink(s2, h3)
info( '*** Starting network\n')
net.build()
info( '*** Starting controllers\n')
for controller in net.controllers:
controller.start()
info( '*** Starting switches\n')
net.get('s1').start([c0])
net.get('s2').start([c0])
info( '*** Post configure switches and hosts\n')
CLI(net)
net.stop()
if __name__ == '__main__':
setLogLevel( 'info' )
myNetwork()
(二)进阶要求
#!/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 ):
def __init__( self ):
Topo.__init__( self )
L1 = 2
L2 = 4
L3 = 8
a = []
b = []
c = []
#创建交换机
for i in range(L1):
sw = self.addSwitch( 's{}'.format( i + 1 ) )
a.append(sw)
for i in range(L2):
sw = self.addSwitch( 's{}'.format( L1+i + 1 ) )
b.append(sw)
for i in range(L3):
sw = self.addSwitch( 's{}'.format( L1+L2+i + 1 ) )
c.append(sw)
#创建交换机间的连接
for i in range(L1):#1-2
sw1=a[i]
for sw2 in b[i//2::L1//2]:
self.addLink(sw2,sw1)
for i in range(0,L2,2):#2-3
for sw3 in b[i:i+2]:
j=i+i
for sw4 in c[j:j+4]:
self.addLink(sw3,sw4)
count = 1
#create hosts and 交换机连接 hosts
for sw5 in c:
for i in range(2):
host = self.addHost( 'h{}'.format( count ) )
self.addLink( sw5, host )
count += 1
topos = { 'mytopo': ( lambda: MyTopo() ) }
总结
虽然本次实验从整体来说偏易。但是,由于我的粗心,导致部分代码打错从而令主机间不能相互连通,导致排查错误花了较多的时间来处理。
而从进阶部分来说实际基本上按照参考资料写下来略微改动即可完成,其中本人不足点在于对于部分代码逻辑敏感度较低,导致二三层间交换机的连线方法想了很久才写出来。
我今后还需多敲点算法类型的代码,增强下自己的代码逻辑。