zoukankan      html  css  js  c++  java
  • Mininet实验 命令延伸实验扩展

    本文参照:Mininet 命令延伸实验扩展

    步骤1:命令行创建拓扑

    sudo mn --topo minimal 最小的网络拓扑,一个交换机下挂两个主机。

    sudo mn --topo linear,4 每个交换机连接一个主机,交换机间相连接。本例:4个主机,4个交换机。

    sudo mn --topo single,3 每个主机都连接到同一个交换机上。本例:3个主机,一个交换机。

    sudo mn --topo tree,fanout=2,depth=2 定义深度和扇出形成基于树的拓扑。本例:深度2,扇出2。
    这个命令的大概意思是 形成类似一棵树的拓扑。
    注意:建议自己手打一遍。

    可以看到,建立了一个如下拓扑:

        s1
      s2  s3
    h1 h2 h3 h4
    

    步骤2:交互式界面创建主机、交换机等

    sudo mn

    添加主机h3:py net.addHost('h3')

    添加link:py net.addLink(s1,net.get('h3'))

    给交换机s1添加端口eth3用于连接h3:py s1.attach('s1-eth3')

    给h3赋予IP(10.0.0.3):py net.get('h3').cmd('ifconfig h3-eth0 10.3')

    h1 ping h3 :h1 ping -c3 h3

    显示所有网络信息:
    px from mininet.util import dumpNodeConnections
    py dumpNodeConnections(net.hosts)

    所有节点的ping测试:
    py net.pingAll()

    步骤3:python搭建拓扑

    需要在搭建好Mininet的虚拟机上执行。

    --topo linear,4

    命令:
    新建python文件:touch test
    更改文件内容:vim test.py

    from mininet.net import Mininet
    from mininet.topo import LinearTopo
    Linear4 = LinearTopo(k=4)    #四个交换机,分别下挂一个主机
    net = Mininet(topo=Linear4)
    net.start()
    net.pingAll()
    net.stop()
    

    注意,原文(sdnlab的文章)中的注释需要删掉,否则会报错。

    修改权限:chmod +x linear.py
    执行:sudo python test.py

    --topo single,3

    过程参照上文。

    from mininet.net import Mininet
    from mininet.topo import SingleSwitchTopo
    Single3 = SingleSwitchTopo(k=3)   #一个交换机下挂3个主机
    net = Mininet(topo=Single3)
    net.start()
    net.pingAll()
    net.stop()
    

    --topo tree,depth=2,fanout=2

    from mininet.net import Mininet
    from mininet.topolib import TreeTopo
    Tree22 = TreeTopo(depth=2,fanout=2)
    net = Mininet(topo=Tree22)
    net.start()
    net.pingAll()
    net.stop()
    

    非以上三种topu

    下面介绍一种适合各种拓扑形式的脚本创建模式。本例:1个交换机,2个主机,并且赋予主机IP地址。

    from mininet.net import Mininet
    net = Mininet()
    
    # Creating nodes in the network.
    c0 = net.addController()
    h0 = net.addHost('h0')
    s0 = net.addSwitch('s0')
    h1 = net.addHost('h1')
    
    # Creating links between nodes in network
    net.addLink(h0, s0)
    net.addLink(h1, s0)
    
    # Configuration of IP addresses in interfaces
    h0.setIP('192.168.1.1', 24)
    h1.setIP('192.168.1.2', 24)
    net.start()
    net.pingAll()
    net.stop()
    

    性能限制

    除了可以通过Python脚本创建基本的拓扑以外,还能在此基础上对性能进行限制。观察下面给出的脚本文件,addHost()语法可以对主机cpu进行设置,以百分数的形式;addLink()语法可以设置带宽bw、延迟delay、最大队列的大小max_queue_size、损耗率loss。

    from mininet.net import Mininet
    from mininet.node import CPULimitedHost
    from mininet.link import TCLink
    
    net = Mininet(host=CPULimitedHost, link=TCLink)
    c0 = net.addController()
    s0 = net.addSwitch('s0')
    h0 = net.addHost('h0')
    h1 = net.addHost('h1', cpu=0.5)
    h2 = net.addHost('h1', cpu=0.5)
    
    net.addLink(s0, h0, bw=10, delay='5ms', max_queue_size=1000, loss=10, use_htb=True)
    
    net.addLink(s0, h1)
    net.addLink(s0, h2)
    net.start()
    net.pingAll()
    net.stop()
    


    注意:原文中最长的net.addLink()语句是分开的,ping会失效。

    2016/9/19

  • 相关阅读:
    查前端资料的一些网站
    10.18号笔记
    10.17号笔记
    10.16号笔记
    10.13号笔记
    10.12号笔记
    10.11号笔记
    10.10号笔记
    10.9号笔记
    理想VS现实
  • 原文地址:https://www.cnblogs.com/qq952693358/p/5882931.html
Copyright © 2011-2022 走看看