熟悉Mininet自定义拓扑三种实现方式:命令行创建、Python脚本编写、交互式界面创建。
Mininet 是一个轻量级软件定义网络和测试平台;它采用轻量级的虚拟化技术使一个单一的系统看起来像一个完整的网络运行想过的内核系统和用户代码,也可简单理解为 SDN 网络系统中的一种基于进程虚拟化平台,它支持 OpenFlow、OpenvSwith 等各种协议,Mininet 也可以模拟一个完整的网络主机、链接和交换机在同一台计算机上且有助于互动开发、测试和演示,尤其是那些使用 OpenFlow 和 SDN 技术;同时也可将此进程虚拟化的平台下代码迁移到真实的环境中。
本实验分别通过命令行创建、Python脚本编写以及交互式界面创建来熟悉Mininet的基本功能。
本实验需要安装支持OpenFlow1.3协议的Mininet镜像。
步骤1:命令行创建拓扑
(1)最小的网络拓扑,一个交换机下挂两个主机。
#sudo mn --topo minimal
(2)每个交换机连接一个主机,交换机间相连接。本例:4个主机,4个交换机。
#sudo mn --topo linear,4
(3)每个主机都连接到同一个交换机上。本例:3个主机,一个交换机。
#sudo mn --topo single,3
(4)定义深度和扇出形成基于树的拓扑。本例:深度2,扇出2。
#sudo mn --topo tree, fanout=2,depth=2
步骤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()
(2)修改文件linear.py为可执行文件。
#chmod +x linear.py
(3)运行脚本。
#sudo python linear.py
2 --topo single,3。
脚本内容如下,具体操作参考步骤2的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。
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地址。
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。
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()
步骤3:交互式界面创建主机、交换机等
#sudo mn
1 添加主机h3。
2 添加link。
3 给交换机s1添加端口eth3用于连接h3。
4 给h3赋予IP(10.0.0.3)。
5 h1 ping h3。
步骤4:测试网络
1 展示所有的网络信息。
2 所有节点的ping测试。
本次实验对Mininet的命令进行了延伸,通过命令行创建、Python脚本编写以及交互式界面创建进一步熟悉Mininet的基本功能。