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

    mininet实验一

    参考博客一

    参考博客二


    实验目的

    • 熟悉Mininet自定义拓扑三种实现方式:命令行创建、Python脚本编写、交互式界面创建。

    1.用命令行生成拓扑,并测试连通性,截图

    1)最小的网络拓扑,一个交换机下面挂两个主机。

    sudo mn --topo minimal
    

    注意:每次要新建拓扑时,需执行以下命令,防止上次操作对本次实验的影响

    sudo mn -c
    

    建立后用exit来退出。


    2)每个交换机连接一个主机,交换机间相连接。本例:4个主机,4个交换机。

    sudo mn --topo linear,4
    

    注意:每次要新建拓扑时,需执行以下命令,防止上次操作对本次实验的影响

    sudo mn -c
    

    3)每个主机都连接到同一个交换机上。本例:3个主机,一个交换机。

    sudo mn --topo single,3
    

    注意:每次要新建拓扑时,需执行以下命令,防止上次操作对本次实验的影响

    sudo mn -c
    

    4)定义深度和扇出形成基于树的拓扑。本例:深度2,扇出2。

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

    注意:每次要新建拓扑时,需执行以下命令,防止上次操作对本次实验的影响

    sudo mn -c
    

    2.Python脚本定义拓扑

    1)--topo linear,4。

    1. 在装有mininet镜像的虚拟机中新建文件linear.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()
    

    建立python文件

    2.修改文件linear.py为可执行文件。

    chmod +x linear.py
    

    3.运行脚本

    sudo python linear.py
    


    2) --topo single,3。

    给出脚本内容,具体操作步骤见例子1。

    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()
    


    3)--topo tree,depth=2,fanout=2。

    给出脚本内容,具体操作步骤见例子1。

    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()
    


    4)如果是非上述三种类型的拓扑,那么下面介绍一种适合各种拓扑形式的脚本创建模式。本例:1个交换机,2个主机,并且赋予主机IP地址。

    给出脚本内容,具体操作步骤见例子1。

    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()
    


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

    给出脚本内容,具体操作步骤见例子1。

    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()
    

    注意:每次要新建拓扑时,需执行以下命令,防止上次操作对本次实验的影响

    sudo mn -c
    

    3.交互式界面创建主机、交换机等

    首先我们要先运行mininet

    sudo mn
    
    

    1)添加主机h3

    py net.addHost('h3')
    


    2)添加link

    py net.addLink(s1,net.get('h3'))
    
    


    3)给交换机s1添加端口eth3用于连接h3

    py s1.attach('s1-eth3')
    
    


    4)给h3赋予IP(10.0.0.3)

    py net.get('h3').cmd('ifconfig h3-eth0 10.3')
    


    5)h1 ping h3

    h1 ping -c1 10.3
    
    


    4.测试网络

    1)展示所有的网络信息。

    px from mininet.util import dumpNodeConnections
    py dumpNodeConnections(net.hosts)
    
    


    2)所有节点的ping测试。

    py net.pingAll()
    
    

    进行这个实验出现了小问题,如果按照之前的步骤来做会有error,运行下面的语句后才恢复正常。

    s1 ping h3
    

  • 相关阅读:
    如何在Ubuntu 20.04 LTS Focal Fossa上安装Jekyll
    如何在CentOS 8 / RHEL 8服务器上安装qBittorrent
    如何在Kubernetes中向节点添加或删除标签
    java--io
    hdfs文件上传下载--client模式--Kerberos认证
    java--正则表达式使用
    Javaweb访问Hdfs--Kerberos认证
    Kerberos常用命令
    druid配置详解
    dubbo详细介绍
  • 原文地址:https://www.cnblogs.com/031602523liu/p/8719479.html
Copyright © 2011-2022 走看看