zoukankan      html  css  js  c++  java
  • SDN1

    实验要求

    • 安装轻量级网络仿真工具Mininet
    • 用字符命令搭建给定的拓扑结构,并写出命令
    • 利用可视化工具搭建给定的拓扑结构,并要求支持OpenFlow 1.0 1.1 1.2 1.3,设置h1(10.0.0.10)、h2(10.0.0.11)、h3(10.0.0.12),拓扑搭建完成后使用命令验证主机ip,查看拓扑端口连接情况
    • 利用Python脚本完成给定的一个Fat-tree型的拓扑(交换机和主机名需与图中一致,即s1s6,h1h8,并且链路正确,请给出Mininet相关截图)
    • 作业链接

    实验操作

    1. 安装轻量级网络仿真工具Mininet

    使用github上的Mininet源安装

    (1)安装git

    sudo apt-get install git
    

    (2)克隆并执行install.sh脚本

    git clone https://github.com/mininet/mininet.git
    cd mininet/util./install.sh
    


    经过漫长等待,完成安装

    2.用字符命令搭建给定的拓扑结构,并写出命令

    (1)打开终端,输入:

    sudo mn --topo linear,3
    


    net命令查看

    (2)打开终端,输入:

    sudo mn --topo tree , fanout=3, depth=2
    

    并输入net命令查看

    3.利用可视化工具搭建给定的拓扑结构

    (1)打开终端,按如下代码输入打开可视化工具

    cd  mininet
    cd  examples
    sudo  ./miniedit.py
    

    (2)搭建如下拓扑

    (3)对设备进行配置,分别给主机h1、h2、h3设置IP地址(10.0.0.10)、(10.0.0.11)、(10.0.0.12)

    (4)在“Edit”中选择“Preferences”,进入此界面,可勾选“Start CLI”,这样的话,就可以命令行界面直接对主机等进行命令操作,也可以选择交换机支持的OpenFlow协议版本

    (5)保存设计好的拓扑结构,点击RUN运行

    (6)使用xterm命令和ifconfig验证主机IP,查看拓扑端口连接情况:

    4.利用Python脚本完成给定的一个Fat-tree型的拓扑

    (1)给定拓扑结构如下

    (2)Python代码

    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 = []
              
            # add core ovs  
            for i in range( L1 ):
                    sw = self.addSwitch( 's{}'.format( i + 1 ) )
                    c.append( sw )
        
            # add aggregation ovs
            for i in range( L2 ):
                    sw = self.addSwitch( 's{}'.format( L1 + i + 1 ) )
                    a.append( sw )
        
            # add edge ovs
     
            # add links between core and aggregation ovs
            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
     
            #add hosts and its links with edge ovs
            count = 1
            for sw1 in a:
                    for i in range(2):
                        host = self.addHost( 'h{}'.format( count ) )
                        self.addLink( sw1, host )
                        count += 1
    topos = { 'mytopo': ( lambda: MyTopo() ) }
    

    (3)打开终端,输入:

    sudo mn --custom fattree.py --topo mytopo --switch ovsk,protocols=OpenFlow10
    

    (4)输入net命令查看:

    实验总结

    通过本次实验,初步了解了SDN。学会了在Ubuntu上使用Git源安装,并通过mininet学会通过各种方法简单搭建一些拓扑结构,并查看端口的连接情况。

  • 相关阅读:
    CentOS7下搭建hadoop2.7.3完全分布式
    在linux命令行利用SecureCRT上传下载文件
    SPDY和HTTP
    哈希表的工作原理
    LVS(Linux Virtual Server)
    Discuz x3 UCenter实现同步登陆原理
    Goroutine(协程)为何能处理大并发?
    缓存与DB数据一致性问题解决的几个思路
    固态硬盘SSD与闪存(Flash Memory)
    堆和栈的区别(转过无数次的文章)
  • 原文地址:https://www.cnblogs.com/JasonL-S/p/11787227.html
Copyright © 2011-2022 走看看