【Mininet从入门到精通】第2讲 Mininet网络从创建到部署

书接上文,上一讲中我们已经搭建好了Mininet的环境,这一讲中我们来运行几个简单的代码对Mininet有一个大概的认识。本人愚见:Mininet最核心的功能就是能模拟出多台交换机(switch)和终端(host),使科研人员和开发人员快速部署网络,方便做实验验证。所以本讲的核心就是怎么快速创建和管理Mininet网络。

注:本文翻译了mininet官方文档http://mininet.org/sample-workflow/,但做了简化,并加入了自己的实验截图。


Mininet能够快速 createinteract withcustomizeshareSDN网络原型,并可以将创建的网络部署到实体硬件上。 本文仅简单介绍Mininet网络从创建到部署的几个步骤,更多细节请参考Mininet walkthrough。

Creating a Network

可以使用命令行创建一个network,例如:

sudo mn --switch ovs --controller ref --topo tree,depth=2,fanout=3
【Mininet从入门到精通】第2讲 Mininet网络从创建到部署_第1张图片

这个命令可以创建一个深度为2的满3叉树network(9个hosts,4个switches),逻辑图如下:

Interacting with a Network

Mininet允许通过CLI(命令行)的方式来管理创建的network。
运行完上面的创建网络的命令,可以看到已经切换到mininet下,接着运行下面的命令,实现了从h2 ping h3,按Ctrl+c停止。

h2 ping h3

任何linux命令或者程序都可以在任意host上单独执行。例如,可以在h2节点开启一个web服务器,从h3节点发出请求,代码如下:

h2 python -m SimpleHTTPServer 80 >& /tmp/http.log &
h3 wget -O - h2
【Mininet从入门到精通】第2讲 Mininet网络从创建到部署_第2张图片

最后可以通过

exit

来退出Mininet的环境。


【Mininet从入门到精通】第2讲 Mininet网络从创建到部署_第3张图片

Customizing a Network

好了,重头戏来了。如果深度定制自己的网络,通过命令行还是比较麻烦。所以,可以通过Mininet的Python API来创建network,例如下面的python脚本:

from mininet.net import Mininet
from mininet.topolib import TreeTopo

tree4 = TreeTopo(depth=2,fanout=2)
net = Mininet(topo=tree4)
net.start()
h1, h4  = net.hosts[0], net.hosts[3]
print h1.cmd('ping -c1 %s' % h4.IP())
net.stop()

该代码创建了一个小型netwotk,具有4个hosts,3个switches,并实现了h1 ping h4。


【Mininet从入门到精通】第2讲 Mininet网络从创建到部署_第4张图片

Sharing a Network

英文原文如下。大体意思就说要做实验的话,可以下载官方的VM镜像,可以被VMware、Xen 、VirtualBox打开,一旦开发出一个SDN网络原型,可以拷贝VM镜像给他人使用,很容易互相分享(打个比喻,有点像word文档,你写完文档可以拷贝给别人,别人在你的基础上更改)。

Mininet is distributed as a virtual machine (VM) image with all dependencies pre-installed, runnable on common virtual machine monitors such as VMware, Xen and VirtualBox. This provides a convenient container for distribution; once a prototype has been developed, the VM image may be distributed to others to run, examine and modify. A complete, compressed Mininet VM is about 1GB. (Mininet can also be installed natively - apt-get install mininet on Ubuntu.) If you are reading a great SIGCOMM (or other) paper about a Software-Defined Network, wouldn’t you like to be able to click, download and run a living, breathing example of the system? If so, consider developing a Mininet version of your own system that you can share with others!

Running on Hardware

英文原文如下。大体意思就是说,通过Mininet创建的网络,可以部署到实体硬件上,以便进行真实的使用、测试。但是,网络中的节点和链路必须对应实际物理设备或物理线路。控制器可以不做修改,因为控制器本来看到的都是逻辑节点和链路,它才不管到底是真的节点还是假的,反正都是逻辑的。这里说个题外话,装过wmware的都知道系统里面会多两个网卡(wmware虚拟出来的),在操作系统看来,这两个网卡和真实的物理网卡没什么区别,都是网卡。

Once a design works on Mininet, it can be deployed on hardware for real-world use, testing and measurement.

To successfully port to hardware on the first try, every Mininet-emulated component must act in the same way as its corresponding physical one. The virtual topology should match the physical one; virtual Ethernet pairs must be replaced by link-level Ethernet connectivity. Hosts emulated as processes should be replaced by hosts with their own OS image. In addition, each emulated OpenFlow switch should be replaced by a physical one configured to point to the controller. However, the controller does not need to change. When Mininet is running, the controller “sees” a physical network of switches, made possible by an interface with well-defined state semantics.

你可能感兴趣的:(【Mininet从入门到精通】第2讲 Mininet网络从创建到部署)