实验1:SDN拓扑实践


一、实验目的

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

二、实验环境

Ubuntu 20.04 Desktop amd64

三、实验要求

(一)基本要求

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

实验1:SDN拓扑实践

使用Mininet的命令行生成如下拓扑:

a) 3台交换机,每个交换机连接1台主机,3台交换机连接成一条线。

实验1:SDN拓扑实践

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

实验1:SDN拓扑实践

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

实验1:SDN拓扑实践
实验1:SDN拓扑实践

编辑(一)中第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, use_htb=True) #和这个

实验1:SDN拓扑实践

(二)进阶要求

编写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.net import Mininet
from mininet.node import RemoteController,CPULimitedHost
from mininet.link import TCLink
from mininet.util import dumpNodeConnections

class MyTopo( Topo ):
    "Simple topology example."

    def __init__( self ):
        "Create custom topo."

        # 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( 'c{}'.format( i + 1 ) )
                c.append( sw )
    
        # add aggregation ovs
        for i in range( L2 ):
                sw = self.addSwitch( 'a{}'.format( L1 + i + 1 ) )
                a.append( sw )
    
        # add edge ovs
        for i in range( L3 ):
                sw = self.addSwitch( 'e{}'.format( L1 + L2 + i + 1 ) )
                e.append(sw)

        # add links between core and aggregation ovs
        for i in range( L1 ):
                sw1 = c[i]
                for sw2 in a[i/2::L1/2]:
                # self.addLink(sw2, sw1, bw=10, delay='5ms', loss=10, max_queue_size=1000, use_htb=True)
			            self.addLink(sw2, sw1)

        # add links between aggregation and 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]: #改这里,边缘主机有四个
			            self.addLink(sw2, sw1)

        #add hosts and its links with edge ovs
        count = 1
        for sw1 in e:
                for i in range(2):
                	host = self.addHost( 'h{}'.format(count) )
                	self.addLink(sw1, host)
                	count += 1
topos = { 'mytopo': ( lambda: MyTopo() ) }

实验1:SDN拓扑实践

四、个人总结

遇到的问题

问题1:用addHost添加主机后无法ping通(实验pdf上好像没有这个步骤):

  • 给新加的主机设ip地址
  • attach交换机和用于建立连接的新端口(之前没出现过的端口)

问题2:fattree建立拓扑后未ping通

看大家的博客好像都没有给主机设ip地址(有懒狗有懒狗!!!)

心得:

本来以为很简单,但还是有些小难,就有小看前面同学的作业找答案(没有抄作业没有抄作业没有抄作业!!!)(只是在吃自助餐:))

遇到的问题和一些没做好的地方在前面总结了

最后:祝老师教师节第二天快乐!!

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/288948.html

(0)
上一篇 2022年9月12日
下一篇 2022年9月12日

相关推荐

发表回复

登录后才能评论