软件定义网络(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程序设计>实验五网络编程与安全实验报告 遇到问题 在刚开始启动客户端或者服务端时,出现了一系列的错误情况,总是提示异常信息 后来经过询问同学,反应将端口号修改一 ...
随机推荐
- 微信小程序对接通联支付
1.首先拿到通联支付开发API:https://aipboss.allinpay.com/know/devhelp/main.php?pid=15#mid=92 2.如果注册通联或者企业认证工作请到: ...
- MyKTV系统项目的感想
不粉身碎骨,何以脱胎换骨! 3月11号,我们迎来S1的尾巴.这期间有温暖,默契,有项目.一切刚刚好.刚刚正式接到KTV这个微微型的项目的时候,还是很害怕的,虽然老师在前两天就已经提到也讲到,KTV系统 ...
- 如何理解算法时间复杂度的表示法O(n²)、O(n)、O(1)、O(nlogn)等?
先从 来说,理论上哈希表就是O(1).因为哈希表是通过哈希函数来映射的,所以拿到一个关键字,用哈希函数转换一下,就可以直接从表中取出对应的值.和现存数据有多少毫无关系,故而每次执行该操作只需要恒定的时 ...
- 要有一颗理财的心 - 读<富爸爸.穷爸爸>
记得工作没多久后的一次加薪的例行谈话.部门经理和我说,不能靠工资过日子,要多想想怎么投资,我的主要财富就是靠投资赚来的.当时第一反应,老板,你不给我加薪找这借口也太牵强了吧.我的收入只有工资,我的工资 ...
- Python开发的入门教程(一)-数据类型、变量
介绍 Python第一门课程,是Python开发的入门教程,将介绍Python语言的特点和适用范围,Python基本的数据类型,条件判断和循环,函数,以及Python特有的切片和列表生成式. Pyth ...
- Docker系列——Docker安装&基础命令
Docker 概述 Docker 是一个开源的应用容器引擎,Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化. ...
- 解决使用git,ssh每次都要输入密码
建议:生成ssh 公钥私钥的时候,不要输入密码. 解决方案: 1.修改密码:使用命令 ssh-keygen -p 然后修改密码的时候直接回车,也就是把密码置空. 2.重新生成ssh key, 用 ss ...
- 寻找猴王小游戏php代码
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Shell编程—结构化命令
1使用if-then语句 f-then语句有如下格式. if command then commands fi bash shell的if语句会运行if后面的那个命令.如果该命令的退出状态码是0(该命 ...
- new操作符创建对象的四个步骤
new操作符创建对象可以分为以下四个步骤: 创建一个空对象 将所创建对象的__proto__属性值设为构造函数的prototype的属性值 执行构造函数中的代码,构造函数中的this指向该对象 返回对 ...