溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何上手Mininet

發(fā)布時(shí)間:2022-02-19 13:42:26 來(lái)源:億速云 閱讀:258 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章給大家分享的是有關(guān)如何上手Mininet的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

Mininet是由斯坦福大學(xué)基于Linux Container架構(gòu)開(kāi)發(fā)的一個(gè)進(jìn)程虛擬化網(wǎng)絡(luò)仿真工具,可以創(chuàng)建一個(gè)包含主機(jī),交換機(jī),控制器和鏈路的虛擬網(wǎng)絡(luò),其交換機(jī)支持OpenFlow,具備高度靈活的自定義軟件定義網(wǎng)絡(luò)。

如何上手Mininet

Mininet 實(shí)現(xiàn)的特性

  • 支持 OpenFlow、OpenvSwitch 等軟定義網(wǎng)路部件
  • 支持系統(tǒng)級(jí)的還原測(cè)試,支持復(fù)雜拓?fù)?,自定義拓?fù)涞?/section>
  • 提供 Python API, 方便多人協(xié)作開(kāi)發(fā)
  • 很好的硬件移植性與高擴(kuò)展性
  • 支持?jǐn)?shù)千臺(tái)主機(jī)的網(wǎng)絡(luò)結(jié)構(gòu)

Miniet 實(shí)現(xiàn)與工作流程

Mininet 的安裝方式比較簡(jiǎn)單通過(guò) Git 源碼和自帶的安裝腳本方式即可安裝在 Linux 系統(tǒng)中,這里我采用了默認(rèn)安裝所有 Mininet 相關(guān)的相關(guān)套件,如:OpenFlow、POX 等工具會(huì)默認(rèn)保存在當(dāng)前用戶的家目錄。 # git clone git://github.com/mininet/mininet # cd mininet/util/ # ./install.sh -a # ls mininet of-dissector oflops oftest openflow pox

創(chuàng)建網(wǎng)絡(luò)

圖 1.簡(jiǎn)單網(wǎng)絡(luò)示例圖
如何上手Mininet

由于 Mininet 支持自定義網(wǎng)絡(luò),這里先引用一個(gè)簡(jiǎn)單網(wǎng)絡(luò)示例如圖 1,在 Mininet 網(wǎng)絡(luò)系統(tǒng)中直接輸入 mn 命令,可以在此系統(tǒng)中創(chuàng)建單層的拓?fù)渚W(wǎng)絡(luò),從中默認(rèn)創(chuàng)建了兩臺(tái) host 和一個(gè)交換機(jī),并且激活了控制器和交換機(jī)。同時(shí)也可以通過(guò)命令 net 查看到鏈路情況,先簡(jiǎn)單列出了示例,如在 Mininet 系統(tǒng)中啟用 Web 服務(wù)器與客戶端。 # mn*** Creating network*** Adding controller*** Adding hosts:h2 h3*** Adding switches:s1*** Adding links:(h2, s1) (h3, s1)*** Configuring hostsh2 h3*** Starting controller*** Starting 1 switchess1*** Starting CLI:mininet>

啟用與關(guān)閉 Web 服務(wù)
mininet> h2 python -m SimpleHTTPServer 80 & #在主機(jī) h2 開(kāi)啟 Web 服務(wù)mininet> h3 wget -O - h2 #主機(jī) h3 上下載 h2 web 站點(diǎn)內(nèi)容--2013-11-04 00:05:40-- http://10.0.0.1/Connecting to 10.0.0.1:80... connected.HTTP request sent, awaiting response... 200 OK…………Length: 760 [text/html.bash_history.wireshark/install-mininet-vm.shmininet/of-dissector/oflops/oftest/openflow/pox/0K 100% 1.65M=0s2013-11-04 00:05:40 (1.65 MB/s) - written to stdout [760/760]
mininet> h2 kill %python # 殺掉 web 進(jìn)程10.0.0.2 - - [04/Nov/2013 00:05:40] "GET / HTTP/1.1" 200 -bash: line 23: kill: python: ambiguous job specPing 測(cè)試`在 Mininet 系統(tǒng)上,實(shí)現(xiàn)兩主機(jī)互連測(cè)試。
`mininet> h2 ping -c4 h3PING 10.0.0.2 (10.0.0.2) 56(84) bytes of data.64 bytes from 10.0.0.2: icmp_req=1 ttl=64 time=1.55 ms64 bytes from 10.0.0.2: icmp_req=2 ttl=64 time=0.094 ms64 bytes from 10.0.0.2: icmp_req=3 ttl=64 time=0.075 ms64 bytes from 10.0.0.2: icmp_req=4 ttl=64 time=0.071 ms

--- 10.0.0.2 ping statistics ---4 packets transmitted, 4 received, 0% packet loss, time 3006msrtt min/avg/max/mdev = 0.071/0.448/1.553/0.638 ms`
**查看節(jié)點(diǎn)與鏈接**
`mininet> nodesavailable nodes are:c0 h2 h3 s1mininet> neth2 h2-eth0:s1-eth2h3 h3-eth0:s1-eth3s1 lo: s1-eth2:h2-eth0 s1-eth3:h3-eth0c0
自定義拓?fù)?/span>

Mininet 支持自定義拓?fù)浣Y(jié)構(gòu),在 mininet/custom 目錄下給出了一個(gè)實(shí)例,如在 topo-2sw-2host.py 文件中定義了一個(gè) mytopo,則可以通過(guò)–topo 選項(xiàng)來(lái)指定使用這一拓?fù)?

圖 2. 自定拓?fù)涫纠?/span>

如何上手Mininet 由于 Mininet 也支持參數(shù)化拓?fù)?,通過(guò) Python 代碼也可以創(chuàng)建一個(gè)靈活的拓?fù)浣Y(jié)構(gòu),也可根據(jù)自定義傳遞進(jìn)去的參數(shù)進(jìn)行配置,并且可重用到多個(gè)環(huán)境中,下面簡(jiǎn)短列出其代碼的大致結(jié)構(gòu)及含義。 #!/usr/bin/python

#!/usr/bin/pythonfrom mininet.topo import Topo
from mininet.net import Mininet
from mininet.util import dumpNodeConnections
from mininet.log import setLogLevel

class SingleSwitchTopo(Topo):
def __init__(self, n=2, **opts):
Topo.__init__(self, **opts)
switch = self.addSwitch('s1') #添加一個(gè)交換機(jī)在拓?fù)渲衒or h in range(n):
host = self.addHost('h%s' % (h + 1)) #添加主機(jī)到拓?fù)渲衧elf.addLink(host, switch) #添加雙向連接拓?fù)鋎ef simpleTest():
topo = SingleSwitchTopo(n=4)
net = Mininet(topo) #主要類(lèi)來(lái)創(chuàng)建和管理網(wǎng)絡(luò)net.start() #啟動(dòng)您的拓?fù)渚W(wǎng)絡(luò)print "Dumping host connections"dumpNodeConnections(net.hosts) #轉(zhuǎn)存文件連接print "Testing network connectivity"net.pingAll() #所有節(jié)點(diǎn)彼此測(cè)試互連net.stop() #停止您的網(wǎng)絡(luò)if __name__ == '__main__':
setLogLevel('info') # 設(shè)置 Mininet 默認(rèn)輸出級(jí)別,設(shè)置 info 它將提供一些有用的信息simpleTest()
驗(yàn)證參數(shù)化拓?fù)浣Y(jié)構(gòu)
# python test-single.py*** Creating network
*** Adding controller
*** Adding hosts:
h2 h3 h4 h5
*** Adding switches:
s1
*** Adding links:
(h2, s1) (h3, s1) (h4, s1) (h5, s1)
*** Configuring hosts
h2 h3 h4 h5
*** Starting controller
*** Starting 1 switches
s1
Dumping host connections
h2 h2-eth0:s1-eth2
h3 h3-eth0:s1-eth3
h4 h4-eth0:s1-eth4
h5 h5-eth0:s1-eth5
Testing network connectivity
*** Ping: testing ping reachability
h2 -> h3 h4 h5
h3 -> h2 h4 h5
h4 -> h2 h3 h5
h5 -> h2 h3 h4
*** Results: 0% dropped (12/12 received)
名字空間 namespace

通常情況下,主機(jī)界面有用獨(dú)立的名字空間 namespace,而控制節(jié)點(diǎn)跟交換節(jié)點(diǎn)都在根名字空間(root namespace)中。如果想要讓所有節(jié)點(diǎn)擁有各自的名字空間,需要添加 –innamespace 參數(shù),即執(zhí)行:mn –innamespace

# mn --innamespace --switch user*** Creating network*** Adding controller*** Adding hosts:h2 h3*** Adding switches:s1*** Adding links:(h2, s1) (h3, s1)c0  s1*** Testing control networks1 -> c0c0 -> s1*** Results: 0% dropped (2/2 received)

*** Configuring hostsh2 h3*** Starting controller*** Starting 1 switchess1*** Starting CLI:
*** Configuring hostsh2 h3*** Starting controller*** Starting 1 switchess1*** Starting CLI:

Mininet 常用操作

表 1.Mininet 常用指令

名稱(chēng)作用
nodes查看全部節(jié)點(diǎn)
net查看鏈路信息
dump輸出各節(jié)點(diǎn)的信息
h2 ping -c 4 h3測(cè)試主機(jī)之間的連通性
iperf兩個(gè)節(jié)點(diǎn)之間用指定簡(jiǎn)單的 TCP 測(cè)試
iperfudp兩個(gè)節(jié)點(diǎn)之間用指定款單 udp 進(jìn)行測(cè)試
noecho運(yùn)行交互窗口,關(guān)閉回應(yīng)
pingpair兩個(gè)主機(jī)將互 ping
help列出命令文檔,查看命令幫助: help command
dpctl在所有叫交換機(jī)
exit/quit退出 mininet 命令行
hX ifconfig查看當(dāng)前那主機(jī)的 ip 地址,如: h2 ifconfig
py/sh執(zhí)行 python 表達(dá)式或運(yùn)行外部 shell 程序


感謝各位的閱讀!關(guān)于“如何上手Mininet”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI