博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【Mininet】Mininet命令延伸实验扩展
阅读量:4708 次
发布时间:2019-06-10

本文共 2455 字,大约阅读时间需要 8 分钟。

实验参考:

实验步骤:

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。

2.Python脚本定义拓扑

1.--topo linear,4

(1).在装有mininet镜像的虚拟机中添加新建文件linear.py,添加以下内容:

from mininet.net import Mininetfrom mininet.topo import LinearTopoLinear4 = LinearTopo(k=4)    #四个交换机,分别下挂一个主机net = Mininet(topo=Linear4)net.start()net.pingAll()net.stop()

 

(2).修改文件linear.py为可执行文件,并运行。

 

 

 

2.--topo single,3

(1).同上,新建single.py文件添加以下内容。

from mininet.net import Mininetfrom mininet.topo import SingleSwitchTopoSingle3 = SingleSwitchTopo(k=3)   #一个交换机下挂3个主机net = Mininet(topo=Single3)net.start()net.pingAll()net.stop()

 

(2).修改文件权限并运行脚本(我这里是直接在前一个文件中替换代码,所以文件名没变):

 

3.--topo tree,fanout=2,depth=2

(1).同上,新建single.py文件添加以下内容,并将其修改为可执行文件。

from mininet.net import Mininetfrom mininet.topolib import TreeTopoTree22 = TreeTopo(depth=2,fanout=2)net = Mininet(topo=Tree22)net.start()net.pingAll()net.stop()

 

(2).同上,修改文件权限并运行脚本:

 

4.如果是非上述三种类型的拓扑,那么下面介绍一种适合各种拓扑形式的脚本创建模式。本例:1个交换机,2个主机,并且赋予主机IP地址。

from mininet.net import Mininetnet = 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 networknet.addLink(h0, s0)net.addLink(h1, s0)# Configuration of IP addresses in interfacesh0.setIP('192.168.1.1', 24)h1.setIP('192.168.1.2', 24)net.start()net.pingAll()net.stop()

 

 

5.除了可以通过Python脚本创建基本的拓扑以外,还能在此基础上对性能进行限制。观察下面给出的脚本文件,addHost()语法可以对主机cpu进行设置,以百分数的形式;addLink()语法可以设置带宽bw、延迟delay、最大队列的大小max_queue_size、损耗率loss

from mininet.net import Mininetfrom mininet.node import CPULimitedHostfrom mininet.link import TCLinknet = 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()

 

 

3.交互式界面创建主机、交换机等

 

1.打开mininet,创建一个简单拓扑,并对其进行“添加主机h3”、“添加link”、“给交换机s1添加端口eth3用于连接h3”、“ h3赋予IP10.0.0.3)”、“ h1 ping h3”的操作,结果如下:

 

2.测试当前网络情况,先展示当前的网络信息。

 

 

3.我对所有的结点进行ping测试。一开始我以为是因为网络原因,没有达到预期的效果,主要表现为无法识别新添加的主机h3。

 

查阅资料后发现,应该对原有指令进行修改,指定系统去寻找新添加的主机h3:

 

实验结论:

 

本次实验对Mininet的命令进行了延伸,通过命令行创建、Python脚本编写以及交互式界面创建进一步熟悉Mininet的基本功能。

转载于:https://www.cnblogs.com/ptolemy/p/11255813.html

你可能感兴趣的文章
Queue 队列的用法
查看>>
CDM常用命令
查看>>
游戏开发中常用的设计模式
查看>>
Linux 中/etc/profile、~/.bash_profile 环境变量配置及执行过程
查看>>
JAVA:图形之利用FontMetrics类居中
查看>>
使用rsync同步目录
查看>>
[读码时间] for循环遍历设置所有DIV块元素背景色为红色
查看>>
网页调用迅雷下载文件
查看>>
Python 调用 Shell命令
查看>>
POJ 1159 Palindrome(最长公共子序列)
查看>>
ubuntu下安装fcitx五笔输入法
查看>>
责任链模式(chain of responsibility)
查看>>
[转载]java多线程学习-java.util.concurrent详解(一) Latch/Barrier
查看>>
ionic - 运行起来
查看>>
Shell 输入/输出重定向
查看>>
数据结构与算法分析(C++)读书笔记
查看>>
(转)nginx应用总结(1)--基础认识和应用参数优化配置
查看>>
(转)关于sql和MySQL的语句执行顺序(必看!!!)
查看>>
UVALive 3668 A Funny Stone Game(博弈)
查看>>
信息论随笔2: 交叉熵、相对熵
查看>>