其他分享
首页 > 其他分享> > 实验1:SDN拓扑实践

实验1:SDN拓扑实践

作者:互联网

实验1:SDN拓扑实践

一、实验目的

  1. 能够使用源码安装Mininet;
  2. 能够使用Mininet的可视化工具生成拓扑;
  3. 能够使用Mininet的命令行生成特定拓扑;
  4. 能够使用Mininet交互界面管理SDN拓扑;
  5. 能够使用Python脚本构建SDN拓扑。

二、实验环境

  1. 下载虚拟机软件Oracle VisualBox 或 VMware;
  2. 在虚拟机中安装Ubuntu 20.04 Desktop amd64;

三、实验要求

(一)基本要求

  1. 在Ubuntu系统的home目录下创建一个目录,目录命名为学号。

  2. 在创建的目录下,完成Mininet的源码安装。下图为mininet的安装路径:

  3. 使用Mininet可视化工具,生成下图所示的拓扑,并保存拓扑文件名为学号.py

    配置各主机IP为10.0.0.1,控制器配置保持默认,在Edit中选择Preferences将Star CLI、OpenFlow1.0至1.3都选中。如图:

    使用pingall命令测试主机连通性,并作其他扩展操作:

    在File菜单中选择“Export Level 2 Script”,保存拓扑文件名为学号.py:

  4. 使用Mininet的命令行生成如下拓扑:
    a) 3台交换机,每个交换机连接1台主机,3台交换机连接成一条线。
    使用命令sudo mn --topo=linear,3

    b) 3台主机,每个主机都连接到同1台交换机上。
    使用命令sudo mn --topo=single,3

  5. 在4 b)的基础上,在Mininet交互界面上新增1台主机并且连接到交换机上,再测试新拓扑的连通性。
    使用命令py net.addHost('h4')py net.addLink(h4,s1)

    上面操作的丢包率为50%的原因是“Error : could not parse ping output: ping: None: Temporary failure in name resolution”

  6. 编辑(一)中第3步保存的Python脚本,添加如下网络性能限制,生成拓扑:
    a) h1的cpu最高不超过50%;

    b) h1和s1之间的链路带宽为10,延迟为5ms,最大队列大小为1000,损耗率50。

    打开文件代码进行修改

    源代码:

    h1 = net.addHost('h1', cls=Host, ip='10.0.0.1', defaultRoute=None)
    net.addLink(h1, s1)
    

    修改后的代码:

    h1 = net.addHost('h1', cls=Host, ip='10.0.0.1', defaultRoute=None, cpu=0.5)
    
    net.addLink(h1, s1, bw=10, delay='5ms',max_queue_size=1000, loss=50, use_htb=True)
    

(二)进阶要求

编写Python脚本,生成如下数据中心网络拓扑,要求:

四、实验心得

个人觉得这次实验的内容难度不大。主要的困难和时间花费都在实验环境的配置上。

标签:Mininet,switchs,拓扑,h1,实践,range,SDN,self
来源: https://www.cnblogs.com/1star/p/15259462.html