首页 > 其他分享 >实验1:SDN拓扑实践

实验1:SDN拓扑实践

时间:2022-09-19 12:00:05浏览次数:49  
标签:info mininet 拓扑 实践 self 交换机 import SDN net

实验1:SDN拓扑实践
(一)基本要求
使用Mininet可视化工具,生成下图所示的拓扑,并保存拓扑文件名为学号.py。





使用Mininet的命令行生成如下拓扑:
a) 3台交换机,每个交换机连接1台主机,3台交换机连接成一条线。

b) 3台主机,每个主机都连接到同1台交换机上。

在2 b)的基础上,在Mininet交互界面上新增1台主机并且连接到交换机上,再测试新拓扑的连通性。

编辑基本要求第1步保存的Python脚本,添加如下网络性能限制,生成拓扑:
a) h1的cpu最高不超过50%;
b) h1和s1之间的链路带宽为10,延迟为5ms,最大队列大小为1000,损耗率50。

#!/usr/bin/env python

 from mininet.net import Mininet
 from mininet.node import Controller, RemoteController, OVSController
 from mininet.node import CPULimitedHost, Host, Node
 from mininet.node import OVSKernelSwitch, UserSwitch
 from mininet.node import IVSSwitch
 from mininet.cli import CLI
 from mininet.log import setLogLevel, info
 from mininet.link import TCLink, Intf
 from subprocess import call

     def myNetwork():

   net = Mininet( topo=None,
                  build=False,
                  ipBase='10.0.0.0/8')

   info( '*** Adding controller\n' )
   c0=net.addController(name='c0',
                     controller=Controller,
                     protocol='tcp',
                     port=6633)

   info( '*** Add switches\n')
   s1 = net.addSwitch('s1', cls=OVSKernelSwitch)
   s2 = net.addSwitch('s2', cls=OVSKernelSwitch)

   info( '*** Add hosts\n')
   h1 = net.addHost('h1', cls=Host, ip='10.0.0.1', defaultRoute=None, cpu =0.5)
   h2 = net.addHost('h2', cls=Host, ip='10.0.0.2', defaultRoute=None)
   h3 = net.addHost('h3', cls=Host, ip='10.0.0.3', defaultRoute=None)
   h4 = net.addHost('h4', cls=Host, ip='10.0.0.4', defaultRoute=None)

   info( '*** Add links\n')
   net.addLink(h1, s1, bw=10,delay='5ms',max_queue_size=1000,loss=50,use_htb=True)
   net.addLink(s1, h2)
   net.addLink(s2, h3)
   net.addLink(s2, h4)
   net.addLink(s1, s2)

   info( '*** Starting network\n')
   net.build()
   info( '*** Starting controllers\n')
   for controller in net.controllers:
       controller.start()

   info( '*** Starting switches\n')
   net.get('s1').start([c0])
   net.get('s2').start([c0])

   info( '*** Post configure switches and hosts\n')

   CLI(net)
   net.stop()

if __name__ == '__main__':
   setLogLevel( 'info' )
   myNetwork()

(二)进阶要求
编写Python脚本,生成如下数据中心网络拓扑,要求:
编写.py拓扑文件,命名为“学号_fattree.py”;
必须通过Mininet的custom参数载入上述文件,不得直接使用miniedit.py生成的.py文件;
设备名称必须和下图一致;
使用Python的循环功能实现,不得在代码中手工直接添加设备和链路。

#!/usr/bin/python

"""Custom topology example
Adding the 'topos' dict with a key/value pair to generate our newly defined
topology enables one to pass in '--topo=mytopo' from the command line.
"""

from mininet.topo import Topo
from mininet.node import RemoteController,CPULimitedHost
from mininet.util import dumpNodeConnections
from mininet.link import TCLink
from mininet.net import Mininet

class MyTopo( Topo ):


  def __init__( self ):


      # Initialize topology
      Topo.__init__( self ) #定义一个变量(为创建的交换机)
      L1 = 2 #核心交换机数
      L2 = L1 * 2
      L3 = L2 * 2
      c = [] #核心交换机
      a = []
      e = []

      # add core ovs  
      for i in range( L1 ):
              sw = self.addSwitch( 's{}'.format( i + 1 ) )
              c.append( sw )

      # add aggregation ovs
      for i in range( L2 ):
              sw = self.addSwitch( 's{}'.format( L1 + i + 1 ) )
              a.append( sw ) #在列表末尾追加新的sw对象

      # add edge ovs
      for i in range( L3 ):
              sw = self.addSwitch( 's{}'.format( L1 + L2 + i + 1 ) )
              e.append( sw )

  # add links core aggregation ovs
      for i in range( L1 ):
              sw1 = c[i]
      for sw2 in a[i//2::L1//2]:#整除用//
              self.addLink( sw2, sw1 )

      # add links  aggregation edge ovs
      for i in range( 0, L2, 2 ):
          for sw1 in a[i:i+2]:
              for sw2 in e[i*2:i*2+4]: #aggregation连4台edge
                  self.addLink( sw2, sw1 )

      #add hosts edge 添加主机以及主机和边缘交换机的链路
      count = 1
      for sw1 in e:
          for i in range(2):
              host = self.addHost( 'h{}'.format( count ) ,ip='10.0.0.{}'.format( count ),defaultRoute=None)
              self.addLink( sw1, host )
              count += 1
topos = { 'mytopo': ( lambda: MyTopo() ) }

个人总结
进阶前面的作业不是很难,只要仔细阅读老师下发的pdf就可以完成。其余问题上网查询问题也可以很快解决了。
在此期间我碰到了一个问题是第一题保存的py文件是只读模式,后面需要编辑时通过上网查找怎么更改权限。输入如图片所示才解决

第二个问题在添加第四台主机期间,部分链路是ping不通的,然后通过上网查询才知道没有给第四台机子配IP。
进阶问题难度对我来说有点大,我上网查了许多别人做的实例,在看懂他们py代码之后,进行一点修改。

标签:info,mininet,拓扑,实践,self,交换机,import,SDN,net
From: https://www.cnblogs.com/jiwenyun/p/16707275.html

相关文章

  • 实验2:Open vSwitch虚拟交换机实践
    实验目的1.能够对OpenvSwitch进行基本操作;2.能够通过命令行终端使用OVS命令操作OpenvSwitch交换机,管理流表;3.能够通过Mininet的Python代码运行OVS命令,控制网络拓扑中......
  • 《js 设计模式与开发实践》读书笔记 13
     职责链模式的定义是:使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系,将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它为止。 ......
  • 《js 设计模式与开发实践》读书笔记 14(完)
    在传统面向对象语言中,给对象添加功能常常使用继承的方式,但是继承的方式并不灵活,还会带来许多问题:一方面会导致超类和子类之间存在强耦合性,当超类改变时,子类也会随之改变;另......
  • 微服务低代码Serverless平台(星链)的应用实践
    导读星链是京东科技消金基础研发部研发的一款研发效能提升的工具平台,面向后端服务研发需求,尤其是集成性、场景化、定制化等难度不太高、但比较繁琐的需求,如服务前端的后端......
  • 内容理解在广告场景下的实践和探索
    导读: 内容生态建设是近几年互联网快速发展的关键动因,也是AI化的重点方向之一。本文主要分享在京东广告业务下内容理解体系的建设情况,从标签化、内容准入、质量美学评价等......
  • 实验2:Open vSwitch虚拟交换机实践
    (一)基本要求 1.ovs-vsctl基础操作实践:创建OVS交换机,以ovs-xxxxxxxxx命名,其中xxxxxxxxx为本人学号。在创建的交换机上增加端口p0和p1,设置p0的端口号为100,p1的端口号为101,......
  • 实验2:Open vSwitch虚拟交换机实践
    实验2:OpenvSwitch虚拟交换机实践实验报告1.在/home/用户名/学号/lab2/目录下执行ovs-vsctlshow命令、以及p0和p1连通性测试的执行结果截图2.在/home/用户名/学号/......
  • 实验1:SDN拓扑实践
    实验1:SDN拓扑实践一、实验目的能够使用源码安装Mininet;能够使用Mininet的可视化工具生成拓扑;能够使用Mininet的命令行生成特定拓扑;能够使用Mininet交互界面管理SDN拓......
  • 实验1:SDN拓扑实践
    一、实验目的1.能够使用源码安装Mininet;2.能够使用Mininet的可视化工具生成拓扑;3.能够使用Mininet的命令行生成特定拓扑;4.能够使用Mininet交互界面管理SDN拓扑;5.能够......
  • 实验1:SDN拓扑实践
    一、基础要求*a)第1步Mininet运行结果截图*b)第2步的执行结果截图*c)第3步提交修改过的“学号.py”代码、Mininet运行结果二、进阶要求代码frommininet......