软件定义网络(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程序设计>实验五网络编程与安全实验报告 遇到问题 在刚开始启动客户端或者服务端时,出现了一系列的错误情况,总是提示异常信息 后来经过询问同学,反应将端口号修改一 ...
随机推荐
- 测量定位实践-:C#采集控制
用Halcon已经完成采集,在在C#中不行. 其实还是比较简单,主要是Halcon封装的太好了. 主要是以下几个算子: *打开 Image Acquisitionopen_framegrabber ( ...
- Java并发篇
Java并发篇 作者:星晴(当地小有名气,小到只有自己知道的杰伦粉) 1. Java锁 1.1 乐观锁 1.2 悲观锁 1.3 自旋锁 1.4 Synchronized 同步锁 1.4.1 核心组件 ...
- python列表表达式
[expression for i in iterable if condition] expression 就是对每一个元素的具体操作表达式;iterable是某个可迭代对象,如列表,元组或字符串等 ...
- Trie详解
Trie,又名字典树.单词查找树,可以较高效地实现统计.排序和保存大量的字符串. 顾名思义,Trie是一个树状的结构,按照树型结构来存储字符串,显然是一种以空间换时间的方法.整体上理解和实现都不会很难 ...
- 从request中获取文件流的两种方式,配置文件上传大小
原文地址:https://blog.csdn.net/xyr05288/article/details/80692132
- 利用Python爬虫刷新某网站访问量
前言:前一段时间看到有博友写了爬虫去刷新博客访问量一篇文章,当时还觉得蛮有意思的,就保存了一下,但是当我昨天准备复现的时候居然发现文章404了.所以本篇文章仅供学习交流,严禁用于商业用途 很多人学习p ...
- Matrix4x4
Unity3D开发之Matrix4x4矩阵变换 https://www.cnblogs.com/hewei2012/p/4190282.html Matrix4x4 4x4矩阵 http://wiki ...
- RedisTemplate: Failed to deserialize payload
问题 org.springframework.data.redis.serializer.SerializationException: Cannot deserialize; nested exce ...
- 9.深入k8s:调度器及其源码分析
转载请声明出处哦~,本篇文章发布于luozhiyun的博客:https://www.luozhiyun.com 源码版本是1.19 这次讲解的是k8s的调度器部分的代码,相对来说比较复杂,慢慢的梳理清 ...
- 2020重新出发,NOSQL,Redis主从复制
Redis主从复制 尽管 Redis 的性能很好,但是有时候依旧满足不了应用的需要,比如过多的用户进入主页,导致 Redis 被频繁访问,此时就存在大量的读操作. 对于一些热门网站的某个时刻(比如促销 ...