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

实验1:SDN拓扑实践

时间:2022-09-18 17:46:12浏览次数:61  
标签:Mininet self sw 实践 range sw1 SDN 拓扑

实验1:SDN拓扑实践

一、实验目的

  1. 能够使用源码安装Mininet;
  2. 能够使用Mininet的可视化工具生成拓扑;
  3. 能够使用Mininet的命令行生成特定拓扑;
  4. 能够使用Mininet交互界面管理SDN拓扑;
  5. 能够使用Python脚本构建SDN拓扑。

二、实验环境

Ubuntu 20.04 Desktop amd64

三、实验要求

(一)基本要求

  1. 使用Mininet可视化工具,生成下图所示的拓扑,并保存拓扑文件名为学号.py。

    image

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

    image

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

    image

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

    image

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

    修改过的代码

    
        h1 = net.addHost('h1', cls=Host, ip='10.0.0.1', defaultRoute=None, cpu=0.5)
    	
        net.addLink(h1, s1, bw=10, delay='5ms',max_queue_size=1000, loss=50)
    

    Mininet运行结果
    image

(二)进阶要求

212106617_fattree.py代码

#!/usr/bin/env 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 ):
	 
	    # Initialize topology
	    Topo.__init__( self )
	    L1 = 2
	    L2 = L1 * 2 
	    L3 = L2 * 2
	    first = []
	    second = []
	    third = []
	    count = 1
	      
	    # add core ovs  
	    for i in range( L1 ):
		    sw = self.addSwitch( 's{}'.format( i + 1 ) )
		    first.append( sw )

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

	    # add edge ovs
	    for i in range( L3 ):
		    sw = self.addSwitch( 's{}'.format( L1 + L2 + i + 1 ) )
		    third.append( sw )
	 
	    # add links between core and aggregation ovs
	    for i in range( L1 ):
		    sw1 = first[i]
		    for sw2 in second:
		    	 self.addLink( sw1, sw2 )
	 
	    # add links between aggregation and edge ovs
	    for i in range( L2 ):
	    	t=i
	    	sw1=second[i]
	    	if (i%2)!=0:
	    		t=t-1
	    	t=t*2
	    	for sw2 in third[t:t+4]:
		    	self.addLink( sw1, sw2 )
	 
	    #add hosts and its links with edge ovs
	    for sw1 in third:
		    for i in range(2):
		    	host = self.addHost( 'h{}'.format( count ) )
		    	self.addLink( sw1, host )
		    	count += 1
topos = { 'mytopo': ( lambda: MyTopo() ) }

执行结果截图:
image

image

四、个人总结

这次实验进行的比较顺利,基本没遇到什么问题,在上次解决了python版本问题之后,mn命令都可以正常的执行,以下是总结的注意事项和心得体会。

  • 在新建拓扑之前要执行sudo mn -c命令
  • 执行mn命令时要记得在前面加上sudo
  • 用addHost添加主机后要执行attach命令才能成功ping通
  • Linux 基本常用命令需要掌握,例如 ls, mkdir, rmdir, cd, sudo, git, touch, chmod等等
  • 输入指令或者地址时可以灵活使用 tab 键提高效率,尤其是文件名字较长的时候。也可以直接进入文件夹右键进入 " open in terminal " ,同样也能提高效率
  • Mininet 友好的可视化操作页面有利于快速搭建一个简单测试网络拓扑

标签:Mininet,self,sw,实践,range,sw1,SDN,拓扑
From: https://www.cnblogs.com/mianmian7/p/16705293.html

相关文章

  • 实验1:SDN拓扑实践
    1.使用Mininet可视化工具,生成下图所示的拓扑,并保存拓扑文件名为学号.py。2.使用Mininet的命令行生成如下拓扑:a)3台交换机,每个交换机连接1台主机,3台交换机连接成一条线......
  • 实验1:SDN拓扑实践
    一、实验目的能够使用源码安装Mininet;能够使用Mininet的可视化工具生成拓扑;能够使用Mininet的命令行生成特定拓扑;能够使用Mininet交互界面管理SDN拓扑;能够使用Python......
  • 实验2:Open vSwitch虚拟交换机实践
    实验报告1.在/home/用户名/学号/lab2/目录下执行ovs-vsctlshow命令、以及p0和p1连通性测试的执行结果截图2.在/home/用户名/学号/lab2/目录下开启MininetCLI并执......
  • 实践考核c++
    /*people是基类,student和graduate是子类,重载“==”运算符输入2个学生的信息:姓名、编号、身份证号、班级、专业输入1个研究生的信息:姓名、编号、身份证号、班级、专业、导......
  • 实验2 Open vSwitch虚拟交换机实践
    OpenvSwitch虚拟交换机实践实验目的能够对OpenvSwitch进行基本操作能够通过命令行终端使用OVS命令操作OpenvSwitch交换机,管理流表能够通过Mininet的Python代码运行......
  • Kakfa系列丛书推荐之《深入理解Kafka:核心设计与实践原理》
    编者推荐本书从Kafka的基本概念入手,主要从生产端、消费端、服务端等3个方面进行全面的陈述,主要内容包括Kafka的基本使用方式、生产者客户端的使用、消费者客户端的使用......
  • 实验一SDN拓扑实验
    1.使用Mininet可视化工具,生成下图所示的拓扑,并保存拓扑文件名为学号.py。2.使用Mininet的命令行生成如下拓扑:a)3台交换机,每个交换机连接1台主机,3台交换机连接成一条线......
  • 实践中负责任漏洞披露的观察
    实践中负责任漏洞披露的观察ThefacadeoftheFinnishparliamentreflectedonthewindowoftheFinnishParliamentAnnex.Image©LariHuttunen.○在过去的几......
  • sentry 压缩文件后上报的实践
    项目中在使用sentry上传事件的attachment函数过程中发现,附带的log文件是未压缩的,于是有了需求,即需要在sentry内部将未压缩的文件流压缩后再上传给服务器这个需求......
  • 【笔记】拓扑排序(Ⅱ)
    题单0X00P7860[COCI2015-2016#2]ARTUR好题。首先考虑本题与拓扑排序有和关系。可以想到,某些棍子的先后移动顺序是有限制的。比如:这里红色的必须比蓝色的先移动,因为......