Mininet实验 命令延伸实验扩展

本文详细介绍使用Mininet创建不同网络拓扑的方法,包括命令行、交互式界面及Python脚本方式。涵盖线性、单一交换机、树形拓扑等,并介绍了如何设定主机CPU、带宽等性能参数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文参照:Mininet 命令延伸实验扩展

步骤1:命令行创建拓扑

sudo mn --topo minimal 最小的网络拓扑,一个交换机下挂两个主机。
885822-20160918203036228-537767202.png

sudo mn --topo linear,4 每个交换机连接一个主机,交换机间相连接。本例:4个主机,4个交换机。
885822-20160918203111793-108742084.png

sudo mn --topo single,3 每个主机都连接到同一个交换机上。本例:3个主机,一个交换机。
885822-20160918203324584-461057329.png

sudo mn --topo tree,fanout=2,depth=2 定义深度和扇出形成基于树的拓扑。本例:深度2,扇出2。
这个命令的大概意思是 形成类似一棵树的拓扑。
注意:建议自己手打一遍。
885822-20160918203811385-1619148481.png
可以看到,建立了一个如下拓扑:

    s1
  s2  s3
h1 h2 h3 h4

步骤2:交互式界面创建主机、交换机等

sudo mn
885822-20160918205451737-1818611172.png

添加主机h3:py net.addHost('h3')
885822-20160918205640541-2020097303.png

添加link:py net.addLink(s1,net.get('h3'))
885822-20160918205821033-229862051.png

给交换机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
885822-20160918210421558-812978332.png

显示所有网络信息:
px from mininet.util import dumpNodeConnections
py dumpNodeConnections(net.hosts)
885822-20160918211919059-462486620.png

所有节点的ping测试:
py net.pingAll()
885822-20160918212303825-1001205035.png

步骤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

885822-20160918235415292-1720329578.png

--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()

885822-20160919000102164-2105744859.png

--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()

885822-20160919083107277-155898018.png

非以上三种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()

885822-20160919083534387-239708139.png

性能限制

除了可以通过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()

885822-20160919084151199-750119974.png
注意:原文中最长的net.addLink()语句是分开的,ping会失效。

2016/9/19

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值