Openlab实验平台实验--Mininet 常用命令

任务目的

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

  • 4
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值