码迷,mamicode.com
首页 > Web开发 > 详细

实验 3:Mininet 实验——测量路径的损耗率

时间:2020-09-18 03:30:09      阅读:48      评论:0      收藏:0      [点我收藏+]

标签:资料   总结   脚本   需要   for   png   完美解决   pad   一个   

一、实验目的

在实验 2 的基础上进一步熟悉 Mininet 自定义拓扑脚本,以及与损耗率相关的设定;初步了解 Mininet 安装时自带的 POX 控制器脚本编写,测试路径损耗率。

二、实验任务

技术图片

h0 向 h1 发送数据包,由于在 Mininet 脚本中设置了连接损耗率,在传输过程中会丢失一些包,本次实验的目的是展示如何通过控制器计算路径损耗速率(h0-s0-s1-h1)。这里假设控制器预先知道网络拓扑。控制器将向 s0 和 s1 发送flow_stats_request,当控制器接收到来自 s0 的 response 时,将特定流的数据包数保存在 input_pkts 中,当控制器接收到来自 s1 的 response 时,将接收到特定流的数据包数保存在 output_pkts 中,差值就是丢失的数据包数量。基于上述拓扑,编写 Mininet 脚本,设置特定的交换机间的路径损耗速率,然后编写 POX 控制器脚本,实现对路径的损耗率的测量。

三、实验步骤

1. 实验环境

安装了 Ubuntu 18.04.5 Desktop amd64 的虚拟机

2. 实验过程

(1)新建并编辑 pox 脚本 flowstat.py: 在 pox 安装目录下(Mininet 完整安装包含了 pox)执行以下命令运行 pox 脚本

使用到的命令

$ sudo nano flowstat.py
$ ./pox.py flowstat

现在一起看下 flowstat.py 的关键代码:

def _handle_flowstats_received (event):
#stats = flow_stats_to_list(event.stats)
#log.debug("FlowStatsReceived from %s: %s", dpidToStr(event.connection.dpid), stats)
global src_dpid, dst_dpid, input_pkts, output_pkts
#print "src_dpid=", dpidToStr(src_dpid), "dst_dpid=", dpidToStr(dst_dpid)
for f in event.stats:
if f.match.dl_type==0x0800 and f.match.nw_dst==IPAddr("192.168.123.2") and f.match.nw_tos==0x64
and event.connection.dpid==src_dpid:
#print "input: ", f.byte_count, f.packet_count
input_pkts = f.packet_count
if f.match.dl_type==0x0800 and f.match.nw_dst==IPAddr("192.168.123.2") and f.match.nw_tos==0x64
and event.connection.dpid==dst_dpid:
#print "output: ", f.byte_count, f.packet_count
output_pkts = f.packet_count
if input_pkts !=0:
print getTheTime(), "Path Loss Rate =", (input_pkts-output_pkts)*1.0/input_pkts*100, "%"

第 7 行开始,让 h0 ping h1, ,监测 s0 和 和 s1 之间 的 链路。

  1. 如果匹配到以太网类型的包头(0x0800),并且数据包的目的 IP 地址是192.168.123.2(对照后面 Mininet 的脚本发现是 h1),并且连接到控制器的数据平面设备 id 是 s0(h0 ping h1, ,路 链路 s0-s1 上 上 数据 包 是从 从 s0 流向 s1 ,s0 为 源,s1 为 为 目的地),执行 input_pkts = f.packet_count,把数据包数量存入input_pkts;
  2. 同理,如果连接到控制器的数据平面设备 id 是 s1,执行 output_pkts = f.packet_count,把数据包数量存入 output_pkts。
  3. 最后求 input_pkts 和 output_pkts 的差值。一般情况下差值为正,说明链路上数据包有损耗。

运行效果

技术图片

(2)编辑 Mininet 脚本 mymininet4.py

参照拓扑图,新建并编辑 Mininet 脚本 mymininet4.py,控制器因为安装在本机,所以需修改参考资料代码中的控制器地址为 127.0.0.1:6633。

switch.cmd( ‘ovs-vsctl set-controller dp0 tcp:127.0.0.1:6633‘ )
switch1.cmd( ‘ovs-vsctl set-controller dp1 tcp:127.0.0.1:6633‘ )

设置 s0 和 s1 之间链路的丢包率为 0

info( "*** Creating links\n" )
linkopts0=dict(bw=100, delay=‘1ms‘, loss=0)
linkopts1=dict(bw=100, delay=‘1ms‘, loss=0)
link0=TCLink( h0, switch, **linkopts0)
link1 = TCLink( switch, switch1, **linkopts1)
link2 = TCLink( h1, switch1, **linkopts0)

再执行命令运行 Mininet 脚本 mymininet4.py

$ sudo python mymininet4.py

技术图片

Ping 默认是每 1 秒钟测一次,ping 的结果会显示一个丢包率,这里的丢包率是根据 ping 不通的次数占总次数的百分比计算得到的。上图中由于一共 ping 了 20次,每次都能通,所以丢包率是 0。
观察 pox 侧的实时状态更新
平均丢包率为 0,结果符合 Mininet 脚本中设置的损耗率,也有可能出现负值,
可以认为没有丢包。

技术图片

如果修改代码中 s0 和 s1 之间链路的丢包率为 10

info( "*** Creating links\n" )
linkopts0=dict(bw=100, delay=‘1ms‘, loss=0)
linkopts1=dict(bw=100, delay=‘1ms‘, loss=10)
link0=TCLink( h0, switch, **linkopts0)
link1 = TCLink( switch, switch1, **linkopts1)
link2 = TCLink( h1, switch1, **linkopts0)

重新运行 Mininet 脚本 mymininet4.py,20 秒时间的 ping 过程中有 icmp_seq 为
1/2/14/16 共 3 次 ping 不通,所以丢包率计算为 20%。

技术图片

POX 端重新测试,会发现出现丢包现象,但是实际测量出的丢包率会有浮动,链路的性能总体受到了限制。

技术图片

四、实验总结

遇到的问题

在终端新建一个拓扑文件,然后执行时出现如下错误:

技术图片

原因是重复构建了相同的拓扑,我先前直接用命令行创建了一个拓扑结构,没有清除,所以若在.py文件中构建相同的拓扑图时需要先清除掉先前的拓扑结构。

命令如下:

$ sudo mn -c

问题就完美解决了!

实验 3:Mininet 实验——测量路径的损耗率

标签:资料   总结   脚本   需要   for   png   完美解决   pad   一个   

原文地址:https://www.cnblogs.com/wht0207/p/13681701.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!