SDN之Python编程创建多数据中心网络
1.拓扑结构
通过python编程创建一个包含2台核心交换机、4台汇聚交换机、8台边缘交换机和16台主机的网络拓扑,如图示:
2.具体步骤
首先ctrl+alt+T(或右键)打开终端,在/home/shy/mininet/mininet/examples目录下使用sudo vim sdn.py命令新建python脚本文件。
步骤一:编写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 ):
def __init__( self ):
#初始化网络拓扑
Topo.__init__( self )
L1 = 2 #核心交换机数量
L2 = L1 * 2 #汇聚交换机数量
L3 = L2 * 2 #边缘交换机数量
c = [] #存放核心交换机的列表
a = [] #存放汇聚交换机的列表
e = [] #存放边缘交换机的列表
#添加核心交换机
for i in range( L1 ):
sw = self.addSwitch( 'c{}'.format( i + 1) )
c.append( sw )
#添加汇聚交换机
for i in range( L2 ):
sw = self.addSwitch( 'a{}'.format( L1 + i + 1 ) )
a.append( sw )
#添加边缘交换机
for i in range( L3 ):
sw = self.addSwitch( 'c{}'.format( L1 + L2 + i + 1) )
e.append( sw )
#添加核心交换机与聚合交换机之间的链路
for i in range( L1 ):
sw1 = c[i]
for sw2 in a[i//2::L1//2]:
self.addLink( sw2 , sw1 )
#添加聚合交换机与边缘交换机之间的链路
for i in range( 0, L2, 2 ):
for sw1 in a[i:i+2]:
for sw2 in e[i*2:i*2+4]:
self.addLink( sw2, sw1 )
#添加主机与边缘交换机之间的链路
count = 1
for sw1 in e:
for i in range(2):
host = self.addHost( 'h{}'.format( count ) )
self.addLink( sw1 , host )
count += 1
#创建mytopo类的对象
topos = { 'mytopo': ( lambda : MyTopo() ) }
可以看到,文件已经保存在/home/shy/mininet/mininet/examples目录下。
步骤二:验证网络拓扑是否创建成功
在另一个终端中开启OpenDaylight控制器
使用sudo mn --custom sdn.py --topo mytopo --controller=remote,ip=127.0.0.1,port=6633 --switch ovs,protocols=OpenFlow13命令运行python脚本文件。可以看到控制器已经成功监测到了网络拓扑,网络连通性也没有问题。