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脚本文件。可以看到控制器已经成功监测到了网络拓扑,网络连通性也没有问题。
在这里插入图片描述