任务目的
1、掌握使用Mininet命令行创建拓扑的方法。
2、掌握使用Python脚本定义拓扑的方法。
3、掌握使用交互式界面自定义拓扑的实现方法。
任务环境
注:系统默认的账户为root/root@openlab,openlab/user@openlab。
任务内容
1、 通过Mininet命令行创建拓扑来熟悉Mininet的基本功能。
2、 通过Python脚本定义拓扑来熟悉Mininet的基本功能。
3、 通过交互式界面创建拓扑来熟悉Mininet的基本功能。
实验原理
Mininet除了创建默认的网络拓扑之外,还提供了丰富的参数和命令用来设定、网络拓扑、交换机、控制器、MAC地址和链路属性等,以满足使用者在仿真过程中多样性的需求。Mininet常用的网络构建参数及内部交互命令如下所述。
一、网络构建参数
1、设置网络拓扑
–topo用于指定网络拓扑,Mininet支持创建的网络拓扑为:minimal、single、linear和tree。
(1) minimal:创建一个交换机和两个主机相连的简单拓扑。默认无—topo参数的情况下就是这样。其内部实现就是调用了single,2对应的函数。
(2) single,n:设置一个交换机和n个主机相连的拓扑。
(3) linear,n:创建n个交换机,每个交换机只连接一个主机,并且所有交换机成线型排列。
(4) tree,depth=n,fanout=m:创建深度为n,每层树枝为m的树型拓扑。因此形成的拓扑的交换机个数为(mn-1)/(m-1),主机个数为mn。
–custom:在上述已有拓扑的基础上,Mininet支持自定义的拓扑,使用一个简单的Python API即可。—custom需和—topo一起使用,如mn —custom file.py —topo mytopo。
2、设置交换机
–switch:用于选择交换机的种类,主要包括user、ovsbr、ovsk、ivs和lxbr等,无—switch参数的时候,默认就是ovsk即OpenvSwitch交换机。
3、设置控制器
–controller:定义要使用的控制器,主要包括:nox、ryu、ovsc和虚拟机之外的远端控制器。如果没有指定则使用Mininet中默认的控制器。
4、配置MAC地址
–mac:设置MAC地址的作用是增强设备MAC地址的易读性,即将交换机和主机的MAC地址设置为一个较小的、唯一的、易读的ID,以便在后续工作中减少对设备识别的难度。
二、内部交互命令
创建Mininet拓扑成功后,一般可用nodes、dump、net等命令查看拓扑的节点、链路及网络等。Mininet常用的交互命令如下所示。
Mininet常用命令总结:
实验步骤
一、命令行创建拓扑
步骤1. 单击终端图标,打开终端,如下图所示。
步骤2. 执行以下命令,创建最小的网络拓扑,即一个交换机下挂两个主机,结果如下图所示。
$ sudo mn --topo minimal
步骤3. 执行exit退出Mininet。
步骤4. 执行以下命令,创建一个线型拓扑,例如:4个主机,4个交换机,结果如下图所示。
$ sudo mn --topo linear,4
步骤5. 执行exit退出Mininet。
步骤6. 执行以下命令,创建一个单一拓扑,例如:3个主机,1个交换机,结果如下图所示。
$ sudo mn --topo single,3
步骤7. 执行exit退出Mininet。
步骤8. 执行以下命令,创建一个树型拓扑,例如:深度2,扇出2,结果如下图所示。
$ sudo mn --topo tree, fanout=2,depth=2
二、Python脚本创建拓扑
步骤1. 自定义一个线型拓扑,4个交换机依次连接,每个交换机下挂接1个主机。执行
sudo vi linear.py
命令,新建文件linear.py,添加以下内容,并执行wq保存退出。
from mininet.net import Mininet
from mininet.topo import LinearTopo
Linear4 = LinearTopo(k=4) #四个交换机,分别下挂一个主机
net = Mininet(topo=Linear4)
net.start()
net.pingAll()
net.stop()
步骤2. 执行以下命令修改文件linear.py为可执行文件。
$ sudo chmod +x linear.py
步骤3. 执行以下命令,运行脚本,结果如下图所示。
$ sudo python linear.py
步骤4. 自定义一个星型拓扑,一个交换机下面挂接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()
执行结果如下图所示。
步骤5. 自定义一个树型拓扑,深度为2,扇出为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()
执行结果如下图所示。
步骤6. 自定义一个拓扑,包括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()
说明:该脚本适合各种拓扑形式的创建。
步骤7. 除了可以通过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()
三、交互式界面创建主机、交换机
步骤1. 执行 sudo mn 命令,运行Mininet。
步骤2. 执行命令,添加主机h3,如下图所示。
py net.addHost(‘h3’)
步骤3. 执行如下命令,添加s1和h3之间的链路,如下图所示。
py net.addLink(s1,net.get(‘h3’))
步骤4. 执行如下命令,给交换机s1添加端口eth3用于连接h3。
py s1.attach(‘s1-eth3’)
步骤5. 执行如下命令,给h3赋予IP(10.0.0.3)。
py net.get(‘h3’).cmd(‘ifconfig h3-eth0 10.3’)
步骤6. 执行h1 ping h3,查看两台主机间是否能Ping通,如下图所示。
步骤7. 执行dump命令,查看所有节点信息,如下图所示。
由上图可知,h3已成功添加。
四、测试网络
步骤1. 执行如下命令,展示所有的网络信息,如下图所示。
px from mininet.util import dumpNodeConnections
py dumpNodeConnections(net.hosts)
步骤2. 执行如下命令,进行所有节点的Ping测试,如下图所示。
py net.pingAll()