软件定义网络(SDN)第二次实验报告
实验 2 :Mininet 实验——拓扑的命令脚本生成
==========================================
一、实验目的
掌握 Mininet 的自定义拓扑生成方法:命令行创建、Python 脚本编写。
二、实验任务
通过使用命令行创建、Python 脚本编写生成拓扑,熟悉 Mininet 的基本功能。
三、实验要求
- 在创建的个人目录下,修改上述 Mininet 脚本,使之变成一个线性拓扑(交换机和主机数均为 3)。
- 各类性能限制保持不变。
- 使用 iperf 完成拓扑内 3 台主机相互之间的简单性能测试。
- 在博客园发表一篇博客,记录代码和主要步骤。
四、具体实验步骤
引导实验 Part 1
(1)选择 VMware 虚拟机,进入 Ubuntu 18.04.5 Desktop amd64 的实验环境;
(2)针对特定拓扑的命令行快速创建:
- 最小拓扑,1 台交换机下挂 2 台主机;
$ sudo mn --topo minimal

图 2-1 最小拓扑
- 简单拓扑,1 台交换机下挂 n 台主机,此处 n=3,n=2 即为最小拓扑【星型拓扑】;
$ sudo mn --topo single,3

图 2-2 简单拓扑
- 线性拓扑,交换机连成一线,每台交换机下挂 1 台主机,此处有 3 台交换机 3 台主机【总线拓扑】;
$ sudo mn --topo linear,3

图 2-3 线性拓扑
- 树形拓扑,基于深度 depth 和扇出 fanout,此处均为 2【树形拓扑】。
$ sudo mn --topo tree,fanout=2,depth=2

图 2-4 树形拓扑
引导实验 Part 2
(1)通用情形的 Python 脚本自定义创建:
- 输入命令,创建 mytopo.py 文件,用编辑器打开,将代码样例 1 复制进去【脚本中可以自定义网络性能,比如 addHost 当中可以添加参数设置主机的 cpu,addLink 当中可以添加参数设置链路带宽 bw、延时 delay、最大队列值 maxqueuesize、丢包率 loss】;
$ touch mytopo.py

图 2-5 创建代码文件
- 运行.py文件;
$ sudo python mytopo.py

图 2-6 运行代码文件 mytopo.py ,结果一致
(2)同样创建新的文件 IperfTest.py ,将代码样例 2 复制进去,用 iPerf 测试网络拓扑中的指定主机之间的带宽。

图 2-6 运行代码文件 IperfTest.py ,结果一致
本周实验任务完成流程
(1)复制 mytopo.py 为 ch2topo.py ,复制 IperfTest.py 为 ch2Iperf.py ,先进入 ch2topo.py 编辑器;

图 2-7 复制 .py 文件
(2)修改 ch2topo.py 代码拓扑为一个线性拓扑(交换机和主机数均为 3 ),具体代码如下:
# coding=UTF-8
from mininet.net import Mininet
from mininet.node import CPULimitedHost
from mininet.link import TCLink
net = Mininet(host=CPULimitedHost, link=TCLink) # 如不限制性能,参数为空
# 创建网络节点
c0 = net.addController()
s1 = net.addSwitch('s1')
s2 = net.addSwitch('s2')
s3 = net.addSwitch('s3')
h1 = net.addHost('h1', cpu=0.5)
h2 = net.addHost('h2', cpu=0.5)
h3 = net.addHost('h3')
# 创建节点间的链路
net.addLink(h1, s1, bw=10, delay='5ms',max_queue_size=1000, loss=10, use_htb=True)
net.addLink(h2, s2, bw=10, delay='5ms',max_queue_size=1000, loss=10, use_htb=True)
net.addLink(h3, s3, bw=10, delay='5ms',max_queue_size=1000, loss=10, use_htb=True)
net.addLink(s1, s2)
net.addLink(s2, s3)
# 配置主机 ip
h1.setIP('10.0.0.1', 24)
h2.setIP('10.0.0.2', 24)
h3.setIP('10.0.0.3', 24)
net.start()
net.pingAll()
net.stop()

图 2-8 修改代码的拓扑结构
(3)多次运行 ch2topo.py 文件,查看结果;

图 2-9 运行 ch2topo.py 文件
(4)同理修改 ch2Iperf.py 代码拓扑为一个线性拓扑(交换机和主机数均为 3 ),并进行三台主机两两之间相互的性能测试,具体代码如下:
# coding=UTF-8
#!/usr/bin/python
from mininet.net import Mininet
from mininet.node import CPULimitedHost
from mininet.link import TCLink
from mininet.util import dumpNodeConnections
from mininet.log import setLogLevel
def IperfTest():
net = Mininet(host=CPULimitedHost, link=TCLink)
c0 = net.addController()
h1 = net.addHost('h1', cpu=0.5)
h2 = net.addHost('h2', cpu=0.5)
h3 = net.addHost('h3')
s1 = net.addSwitch('s1')
s2 = net.addSwitch('s2')
s3 = net.addSwitch('s3')
net.addLink(h1, s1, bw=10, delay='5ms',max_queue_size=1000, loss=0, use_htb=True)
net.addLink(h2, s2, bw=10, delay='5ms',max_queue_size=1000, loss=0, use_htb=True)
net.addLink(h3, s3, bw=10, delay='5ms',max_queue_size=1000, loss=0, use_htb=True)
net.addLink(s1, s2)
net.addLink(s2, s3)
h1.setIP('10.0.0.1', 24)
h2.setIP('10.0.0.2', 24)
h3.setIP('10.0.0.3', 24)
net.start()
print "Dumping host connections"
dumpNodeConnections(net.hosts)
print "Testing network connectivity"
net.pingAll()
print "Testing bandwidth"
h1, h2, h3 = net.get('h1', 'h2', 'h3')
net.iperf((h1, h3))
net.iperf((h3, h1))
net.iperf((h1, h2))
net.iperf((h2, h1))
net.iperf((h2, h3))
net.iperf((h3, h2))
net.stop()
if __name__=='__main__':
setLogLevel('info')
#print the log when Configuring hosts, starting switches and controller
IperfTest()

图 2-9 运行 ch2topo.py 文件
五、注意事项与心得体会
注意事项
- 本周暂无,实验比较简单。
心得体会
- 学会了用 python 编写 mininet 脚本和网络拓扑,以后可以自定义;
- 有个问题:如果需要创建一个规模比较大的测试拓扑的话(除去简单拓扑、线性拓扑、树形拓扑),这样子用图形化或者脚本化界面来一一配置,效率会不会比较低,是否存在以及如何进行高效率部署。
软件定义网络(SDN)第二次实验报告的更多相关文章
- 20145240 《Java程序设计》第二次实验报告
20145240 <Java程序设计>第二次实验报告 北京电子科技学院(BESTI)实验报告 课程:Java程序设计 班级:1452 指导教师:娄嘉鹏 实验日期:2016.04.12 实验 ...
- 20145330《Java程序设计》第二次实验报告
20145330<Java程序设计>第二次实验报告 实验二 Java面向对象程序设计 实验内容 1.初步掌握单元测试和TDD 2.理解并掌握面向对象三要素:封装.继承多态 3.初步掌握UM ...
- 20145320《Java程序设计》第二次实验报告
20145320<Java程序设计>第二次实验报告 北京电子科技学院(BESTI)实验报告 课程:Java程序设计 班级:1453 指导教师:娄嘉鹏 实验日期:2016.04.12 15: ...
- 20145211 《Java程序设计》实验报告五————Java网络编程及安全实验报告
实验内容 1.掌握Socket程序的编写: 掌握密码技术的使用: 设计安全传输系统. 实验步骤 这一部分是与我的partner合作的,详见他的博客- [20145326 <Java程序设计> ...
- 《Java程序设计》第二次实验报告
20145220 <Java程序设计>第二次实验报告 课程:Java程序设计 指导教师:娄嘉鹏 实验日期:2016.04.12 实验名称:Java面向对象程序设计 实验内容 初步掌握单元测 ...
- DevOps之软件定义网络SDN
唠叨话 关于德语噢屁事的知识点,仅提供专业性的精华汇总,具体知识点细节,参考教程网址,如需帮助,请留言. <软件定义网络SDN(Software Defined Network)> 关于软 ...
- 20155326 《Java程序设计》实验五网络编程与安全实验报告
20155326 <Java程序设计>实验五网络编程与安全实验报告 实验内容 任务一 1.两人一组结对编程: 参考http://www.cnblogs.com/rocedu/p/67667 ...
- 20155227 《Java程序设计》实验五 Java网络编程及安全实验报告
20155227 <Java程序设计>实验五 Java网络编程及安全实验报告 实验内容 任务一: 编写MyBC.java实现中缀表达式转后缀表达式的功能. 编写MyDC.java实现从上面 ...
- 20155305 2016-2017-2 《Java程序设计》 实验五 Java网络编程及安全实验报告
20155305 2016-2017-2 <Java程序设计> 实验五 Java网络编程及安全实验报告 实验内容 1.掌握Socket程序的编写. 2.掌握密码技术的使用. 3.设计安全传 ...
- 20155317 《Java程序设计》实验五网络编程与安全实验报告
20155317 <Java程序设计>实验五网络编程与安全实验报告 遇到问题 在刚开始启动客户端或者服务端时,出现了一系列的错误情况,总是提示异常信息 后来经过询问同学,反应将端口号修改一 ...
随机推荐
- day7 地址 名片管理系统
1 无限循环 (while True) break 退出 人为设计的 ,并且有退除的出口 死循环 bug 错误 2.引用 数字型
- Redis设计与实现——多机数据库的实现
复制 旧版Redis的复制功能分为同步(sync)和命令传播两个操作. sync:是一个非常耗费资源的操作 命令传播 ...
- powerMock和mockito使用
powerMock和mockito powermock和mockito都是做mock的框架,powermock在mockito的基础上扩展而来,支持mockito的操作(也支持别的mock框架比如ea ...
- Istio Routing 实践掌握virtualservice/gateway/destinationrule/AB版本发布/金丝雀发布
原文 在学习像 Istio 这样的新技术时,看一下示例应用程序总是一个好主意. Istio repo 有一些示例应用程序,但它们似乎有各种不足. 文档中的 BookInfo 是一个很好的示例. 但是, ...
- C# IObservable与IObserver观察者模式
C#中提供了IObservable<T>接口和IObserver<T>接口来实现观察者模式,IObservable<T>相当于Subject(主题)接口,下面我们就 ...
- Java代替if和switch的方法(记录一下)
package xcc.mapTest; /** * @Decription: 接口 * @Author: * @Date: * @Email: **/ public interface Functi ...
- linux驱动之模块化驱动Makefile
本文摘自http://blog.csdn.net/lufeiop02/article/details/6446343 Linux驱动一般以模块module的形式来加载,首先需要把驱动编译成模块的形式. ...
- 封装Vue Element的form表单组件
前两天封装了一个基于vue和Element的table表格组件,阅读的人还是很多的,看来大家都是很认同组件化.高复用这种开发模式的,毕竟开发效率高,代码优雅,逼格高嘛.虽然这两天我的心情很糟糕,就像& ...
- linux云服务器搭建 express后台 nginx转发
购买云服务器 或者自己在本地搭建一个虚拟机 (我用的是腾讯云云服务器(CVM),或者可以购买阿里云 ecs服务器) 购买完成后 配置安全组 允许http https ftp 端口 一般运营商会提供说明 ...
- Vscode配置C++环境
(终于申请博客了qaq) 之前用了那么久Dev-C++,总算换了一个编辑器,Visual Studio Code (Vscode). 界面可比以前的舒适多了. Vscode作为一款功能极其丰富的开发工 ...