SDN初體驗(軟件定義網絡實驗一)


作業說明

本次實驗步驟2、3是在機房環境下完成的,步驟1、4是在自己筆記本上重新配置完成的,所以環境、用戶名什么的會略有差別。

1. 安裝輕量級網絡仿真工具Mininet

為了節約課程時間,實驗室機房PC已經安裝了Mininet,請大家在課后在自己的Ubuntu系統或虛擬機中嘗試安裝,並記錄安裝步驟。
我所采用的是依照給定的github上mininet源安裝,在自己的新建虛擬機下進行安裝。

一、安裝git

sudo apt install git

二、安裝mininet

git clone http://github.com/mininet/mininet.git
cd mininet/util
./install.sh -a

三、測試mininet

sudo mn

不知道為什么出錯了,這邊使用ubuntu源內安裝解決
sudo apt-get install mininet

sudo mn

2. 用字符命令搭建如下拓撲,要求寫出命令

第一個拓撲是三台主機分別連接交換機,然后三台交換機連接在一起,是一個線性結構。

sudo mn --topo linear,3

第二個拓撲是一個交換機連接三個交換機,每台交換機連接三個主機,是一個深度2、寬度3的樹形結構。

sudo mn --topo tree,fanout=3,depth=2

3. 利用可視化工具搭建如下拓撲,並要求支持OpenFlow 1.0 1.1 1.2 1.3,設置h1(10.0.0.10)、h2(10.0.0.11)、h3(10.0.0.12),拓撲搭建完成后使用命令驗證主機ip,查看拓撲端口連接情況。

通過終端打開miniedit,將圖示拓撲畫上。
(小插曲:一直找不到控制器與交換機之間的虛線在哪里,所以愣神了很久,其實就是左側的藍色線,如果能夠不想那么多,直接上手的話應該能夠更早發現,節省一定的時間。這就告訴我們:猶豫就會敗北)

通過部件的Properties屬性設置主機的IP地址。

通過edit欄下的Preferences設置交換機支持的OpenFlow協議版本。

使用命令驗證主機IP。
xterm h1 h2 h3

4. 利用Python腳本完成如下圖所示的一個Fat-tree型的拓撲(交換機和主機名需與圖中一致,即s1s6,h1h8,並且鏈路正確,請給出Mininet相關截圖)

使用文本編輯器編輯linear.py文件

在文件對應位置下建立拓撲
sudo mn --custom linear.py --topo mytopo

具體代碼如下:

"""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
        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 )
    
        # add edge ovs
 
        # 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
 
        #add hosts and its links with edge ovs
        count = 1
        for sw1 in a:
                for i in range(2):
                    host = self.addHost( 'h{}'.format( count ) )
                    self.addLink( sw1, host )
                    count += 1
topos = { 'mytopo': ( lambda: MyTopo() ) }


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM