zoukankan      html  css  js  c++  java
  • 实验1:SDN拓扑实践

    实验1:SDN拓扑实践

    一、实验目的

    • 能够使用源码安装Mininet;

    • 能够使用Mininet的可视化工具生成拓扑;

    • 能够使用Mininet的命令行生成特定拓扑;

    • 能够使用Mininet交互界面管理SDN拓扑;

    • 能够使用Python脚本构建SDN拓扑。

    二、实验环境

    • 下载虚拟机软件Oracle VisualBox 或 VMware;

    • 在虚拟机中安装Ubuntu 20.04 Desktop amd64;

    三、实验要求

    (一)基本要求

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

    • 在创建的目录下,完成Mininet的源码安装。

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

    a)搭建拓扑

    b)学号为拓扑文件名

    • 使用Mininet的命令行生成如下拓扑:

      a) 3台交换机,每个交换机连接1台主机,3台交换机连接成一条线。

    生成参数为3的线性拓扑,如图所示

    b) 3台主机,每个主机都连接到同1台交换机上。

    生成简单拓扑,如图所示

    • 在4 b)的基础上,在Mininet交互界面上新增1台主机并且连接到交换机上,再测试新拓扑的连通性。

    如图所示,新主机h1连到s1上,连通性已测试

    • 编辑(一)中第3步保存的Python脚本,添加如下网络性能限制,生成拓扑:

      a) h1的cpu最高不超过50%;

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

    • python脚本内改动代码如图

    • 目前python脚本是只读模式,sudo chmod -R 777 文件名(031902344)解除只读

      生成拓扑

    (二)进阶要求

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

    • 编写.py拓扑文件,命名为“学号_fattree.py”;

    • 必须通过Mininet的custom参数载入上述文件,不得直接使用miniedit.py生成的.py文件;

    • 设备名称必须和下图一致;

    • 使用Python的循环功能实现,不得在代码中手工直接添加设备和链路。

    python文件1.0(初次尝试,之前对python不是很熟悉,暴力解题)

    python文件2.0(快速学习python)

    代码如下

    #!/usr/bin/python
    #创建网络拓扑
    """Custom topology example
    Adding the 'topos' dict with a key/value pair to generate our newly defined
    topology enables one to pass in '--topo=mytopo' from the command line.
    """
     
    from mininet.topo import Topo
    from mininet.net import Mininet
    from mininet.node import RemoteController,CPULimitedHost
    from mininet.link import TCLink
    from mininet.util import dumpNodeConnections
     
    class MyTopo( Topo ):
        "Simple topology example."
     
        def __init__( self ):
            "Create custom topo."
     
            # Initialize topology
            Topo.__init__( self )
            L1 = 2
            L2 = L1 * 2 
            L3 = L2
            c = []
            a = []
            e = []
        for i in range( L1 ):
            sw = self.addSwitch( 's{}'.format( i + 1 ) )
            c.append( sw )
        for i in range( L2 ):
            sw = self.addSwitch( 's{}'.format(L1 + i + 1 ) )
            a.append( sw )
        for i in range( L3 ):
            sw = self.addSwitch( 's{}'.format(L1 + L2 + i + 1 ) )
            e.append( sw )
        for i in range(L1):
            sw1 = c[i]
            for sw2 in a[i//2::L1//2]:
       #self.addLink(sw2,sw1,bw=10,delay='5ms',loss=10,max_queue_size=1000, use_htb=True)
            self.addLink(sw2, sw1)
        # add links between aggregation and edge ovs
        for i in range(0, L2, 2):
             for sw1 in a[i:i+2]:
    	 for sw2 in e[i:i+2]: 
             self.addLink(sw2, sw1)
        #add hosts and its links with edge ovs
        count = 1
        for sw1 in e:
            for i in range(2):
                host = self.addHost('h{}'.format(count))
                self.addLink(sw1, host)
                count += 1
        topos = {'mytopo': (lambda: MyTopo())}
    
    • 利用custom参数加载py文件建立拓扑

    四、个人总结

    本次实验遇到的问题

    • 由于安装不顺利,多次反复强制退出和重启,导致内核被大量占用,输入密码进入主页面后直接黑屏卡死,更多次重启后完全无法开机

      解决办法:关机时使用 sudo poweroff,尽量不要强制退出,清理任务管理器,不要同时开多个虚拟机。

    • mininet安装后虚拟机系统运行时,电脑经常运行缓慢,经常卡死(所以我才一直重启,企图拯救它,结果差点直接把它搞崩)

      解决方法:调高设置中分配给虚拟机的处理器数量,多分配内存。

    • mininet可视化工具一直打不开,检查后发现python2和python3都已安装,且显示command not found
      解决办法:按照目录一个一个打开,发现到最后还是python not found,能找到python2和python3,找不到python,建立软连接解决。

    • python编程不熟悉

      解决办法:快速自学。

    实验心得

    通过本次实验,我学会了使用源码安装Mininet、使用Mininet的可视化工具生成拓扑、使用Mininet的命令行生成特定拓扑、使用Mininet交互界面管理SDN拓扑、使用Python脚本构建SDN拓扑.不仅如此,本次实验还大大锻炼了我快速自学的能力,以及面对一些突发状况自己查找资料解决问题的能力。通过实践让我们更加直观的了解软件是如何定义网络的,我相信这对我们的未来学习将大有裨益。

  • 相关阅读:
    基于贝叶斯的垃圾邮件过滤器 JAVA
    Python运行异常 Original error was: DLL load failed:
    Python运行异常 Original error was: DLL load failed:
    数据标准化的方法与意义
    数据标准化的方法与意义
    神经网络为什么要归一化
    神经网络为什么要归一化
    梯度下降与delta法则
    梯度下降与delta法则
    from表格
  • 原文地址:https://www.cnblogs.com/zhaoruiyan955/p/15247378.html
Copyright © 2011-2022 走看看