本文参照:Mininet 命令延伸实验扩展
步骤1:命令行创建拓扑
sudo mn --topo minimal 最小的网络拓扑,一个交换机下挂两个主机。
sudo mn --topo linear,4 每个交换机连接一个主机,交换机间相连接。本例:4个主机,4个交换机。
sudo mn --topo single,3 每个主机都连接到同一个交换机上。本例:3个主机,一个交换机。
sudo mn --topo tree,fanout=2,depth=2 定义深度和扇出形成基于树的拓扑。本例:深度2,扇出2。
这个命令的大概意思是 形成类似一棵树的拓扑。
注意:建议自己手打一遍。
可以看到,建立了一个如下拓扑:
s1
s2 s3
h1 h2 h3 h4
步骤2:交互式界面创建主机、交换机等
sudo mn
添加主机h3:py net.addHost('h3')
添加link:py net.addLink(s1,net.get('h3'))
给交换机s1添加端口eth3用于连接h3:py s1.attach('s1-eth3')
给h3赋予IP(10.0.0.3):py net.get('h3').cmd('ifconfig h3-eth0 10.3')
h1 ping h3 :h1 ping -c3 h3
显示所有网络信息:
px from mininet.util import dumpNodeConnections
py dumpNodeConnections(net.hosts)
所有节点的ping测试:
py net.pingAll()
步骤3:python搭建拓扑
需要在搭建好Mininet的虚拟机上执行。
--topo linear,4
命令:
新建python文件:touch test
更改文件内容:vim test.py
from mininet.net import Mininet
from mininet.topo import LinearTopo
Linear4 = LinearTopo(k=4) #四个交换机,分别下挂一个主机
net = Mininet(topo=Linear4)
net.start()
net.pingAll()
net.stop()
注意,原文(sdnlab的文章)中的注释需要删掉,否则会报错。
修改权限:chmod +x linear.py
执行:sudo python test.py
--topo single,3
过程参照上文。
from mininet.net import Mininet
from mininet.topo import SingleSwitchTopo
Single3 = SingleSwitchTopo(k=3) #一个交换机下挂3个主机
net = Mininet(topo=Single3)
net.start()
net.pingAll()
net.stop()
--topo tree,depth=2,fanout=2
from mininet.net import Mininet
from mininet.topolib import TreeTopo
Tree22 = TreeTopo(depth=2,fanout=2)
net = Mininet(topo=Tree22)
net.start()
net.pingAll()
net.stop()
非以上三种topu
下面介绍一种适合各种拓扑形式的脚本创建模式。本例:1个交换机,2个主机,并且赋予主机IP地址。
from mininet.net import Mininet
net = Mininet()
# Creating nodes in the network.
c0 = net.addController()
h0 = net.addHost('h0')
s0 = net.addSwitch('s0')
h1 = net.addHost('h1')
# Creating links between nodes in network
net.addLink(h0, s0)
net.addLink(h1, s0)
# Configuration of IP addresses in interfaces
h0.setIP('192.168.1.1', 24)
h1.setIP('192.168.1.2', 24)
net.start()
net.pingAll()
net.stop()
性能限制
除了可以通过Python脚本创建基本的拓扑以外,还能在此基础上对性能进行限制。观察下面给出的脚本文件,addHost()语法可以对主机cpu进行设置,以百分数的形式;addLink()语法可以设置带宽bw、延迟delay、最大队列的大小max_queue_size、损耗率loss。
from mininet.net import Mininet
from mininet.node import CPULimitedHost
from mininet.link import TCLink
net = Mininet(host=CPULimitedHost, link=TCLink)
c0 = net.addController()
s0 = net.addSwitch('s0')
h0 = net.addHost('h0')
h1 = net.addHost('h1', cpu=0.5)
h2 = net.addHost('h1', cpu=0.5)
net.addLink(s0, h0, bw=10, delay='5ms', max_queue_size=1000, loss=10, use_htb=True)
net.addLink(s0, h1)
net.addLink(s0, h2)
net.start()
net.pingAll()
net.stop()
注意:原文中最长的net.addLink()语句是分开的,ping会失效。
2016/9/19