实验1:SDN拓扑实践
作者:互联网
实验1:SDN拓扑实践
一、实验目的
能够使用源码安装Mininet;
能够使用Mininet的可视化工具生成拓扑;
能够使用Mininet的命令行生成特定拓扑;
能够使用Mininet交互界面管理SDN拓扑;
能够使用Python脚本构建SDN拓扑。
二、实验要求
1Mininet运行结果截图
2的执行结果截图
使用Mininet的命令行生成如下拓扑:
a) 3台交换机,每个交换机连接1台主机,3台交换机连接成一条线。
b) 3台主机,每个主机都连接到同1台交换机上。
3修改过的“学号.py”代码、Mininet运行结果
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')
s2 = net.addSwitch('s2', cls=OVSKernelSwitch)
s1 = net.addSwitch('s1', 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)
h4 = net.addHost('h4', cls=Host, ip='10.0.0.4', defaultRoute=None)
h3 = net.addHost('h3', cls=Host, ip='10.0.0.3', defaultRoute=None)
info( '*** Add links\n')
net.addLink(h1, s1, bw=10, delay='5ms',max_queue_size=1000, loss=50, use_htb=True)
net.addLink(h2, s1)
net.addLink(h3, s2)
net.addLink(h4, s2)
net.addLink(s1, s2)
info( '*** Starting network\n')
net.build()
info( '*** Starting controllers\n')
for controller in net.controllers:
controller.start()
info( '*** Starting switches\n')
net.get('s2').start([c0])
net.get('s1').start([c0])
info( '*** Post configure switches and hosts\n')
CLI(net)
net.stop()
if __name__ == '__main__':
setLogLevel( 'info' )
myNetwork()
进阶要求
代码
from mininet.topo import Topo
class MyTopo(Topo):
def __init__(self):
Topo.__init__(self)
#hosts
hosts=[]
for i in range(16):
h =self.addHost('h'+str(i+1))
hosts.append(h)
#switchs
switchs=[]
for i in range(14):
s =self.addSwitch('s'+str(i+1))
switchs.append(s)
#links
#switch to switch
for i in range(0,2):
for j in range(2,6):
self.addLink(switchs[i],switchs[j])
for i in range(2,4):
for j in range(6,10):
self.addLink(switchs[i],switchs[j])
for i in range(4,6):
for j in range(10,14):
self.addLink(switchs[i],switchs[j])
#switch to host
for i in range(8):
self.addLink(switchs[i+6],hosts[2*i])
self.addLink(switchs[i+6],hosts[2*i+1])
topos = {'mytopo': (lambda: MyTopo())}
运行结果
个人总结
配置实验环境,其实之前就完成了一大半。由于之前修习过大数据和linux等课程,对于配置有一些了解,加上pdf讲的也很详细,所以实验要求的部分(一)个人觉得实验的内容难度不大,按部就班做下去即可。
在添加新主机和链路之后重新测试连接是出现丢包率为50%的情况“Error : could not parse ping output: ping: None: Temporary failure in name resolution”
标签:info,switchs,addLink,拓扑,实践,self,import,SDN,net 来源: https://www.cnblogs.com/zjl123/p/16688571.html