畢業(yè)論文——基于sdn啞交換機技術(shù)的研究與實踐_第1頁
已閱讀1頁,還剩56頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、<p>  本科畢業(yè)設(shè)計(論文)</p><p>  題目:基于SDN的啞交換機技術(shù)研究與實踐</p><p>  基于SDN啞交換機技術(shù)的研究與實踐</p><p><b>  摘要</b></p><p>  隨著互聯(lián)網(wǎng)的迅速發(fā)展,網(wǎng)絡(luò)服務(wù)類型以及業(yè)務(wù)量不斷增多,因此對傳統(tǒng)的網(wǎng)絡(luò)的性能也提出了更高的要求,但

2、是由于傳統(tǒng)網(wǎng)絡(luò)的局限性,現(xiàn)階段只能在原有網(wǎng)絡(luò)上進行網(wǎng)絡(luò)設(shè)備的增加,協(xié)議的版本升級等手段,網(wǎng)絡(luò)維護工作變得日益復(fù)雜。SDN是一種新興的技術(shù),它的核心思想是控制與轉(zhuǎn)發(fā)分離,網(wǎng)絡(luò)設(shè)備具有開放的可編程接口和網(wǎng)絡(luò)集中控制,SDN大力推動了網(wǎng)絡(luò)的創(chuàng)新,同時在SDN網(wǎng)絡(luò)架構(gòu)里網(wǎng)絡(luò)的設(shè)計,實施,管理也較傳統(tǒng)網(wǎng)絡(luò)架構(gòu)簡單許多。</p><p>  本論文首先介紹了和SDN相關(guān)的一些基礎(chǔ)性概念,其中包括SDN網(wǎng)絡(luò)架構(gòu),南向接口協(xié)議O

3、penflow的技術(shù)原理,以及控制器的相關(guān)知識,然后在虛擬機下搭建符合SDN框架的實驗環(huán)境,最后在這種實驗環(huán)境上實現(xiàn)拓撲的驗證,轉(zhuǎn)發(fā)路徑的驗證以及基于跳數(shù)和帶寬的路徑轉(zhuǎn)發(fā)等實驗。</p><p>  通過相關(guān)實驗的結(jié)果我們得出了,在基于跳數(shù)和帶寬的路徑選擇實驗中,控制器能通過下發(fā)流表來使流量始終走跳數(shù)少的或者帶寬較大的,從而始終保證流量的高效傳輸,這種轉(zhuǎn)發(fā)與控制分離的思想使得網(wǎng)絡(luò)的可控性與靈活性都大大提高。<

4、;/p><p>  關(guān)鍵詞:SDN Mininet Openflow Opendaylight </p><p>  Achieve dumb switch technology on the basis of SDN</p><p><b>  Abstract</b></p><p>  With the deve

5、lopment of the Internet,Types of network services and network traffic is also increasing.so there have a higher requirements to the traditional network,However, due to the limitations of traditional network,At present, w

6、e have to increase the network equipment, upgrade the protocol version, and network maintenance work has become increasingly complex.Software Defined Network(SDN) is an emerging network architecture where network control

7、 is decoupled from forwarding and is directly p</p><p>  First,This paper introduces some basic concepts associated with the SDN, including knowledge SDN network architecture, packet structure to the south O

8、penflow1.0 interface protocol, and controller,Secondly I set up SDN experimental environment in a virtual machine,and finally,Finally, I did some experiments in a SAN environment which including topology verification,Ver

9、ify forwarding path,and path based on hops and forwarding bandwidth experiment.</p><p>  By the result of the experiments we find that the controller will keep the traffic safety, high-speed transmission by

10、issued flow table,for example the controller will choose the less hop in the experiment that based on the hop ,and the controller will choose the lager bandwidth in the experiment that based on the bandwidth , Such forwa

11、rding and control the thought of separation so that the controllability and flexibility of the network are greatly enhanced.</p><p>  Key Words: SDN Mininet Openflow Opendaylight </p><p><

12、b>  目錄</b></p><p><b>  摘要I</b></p><p>  AbstractII</p><p><b>  1 緒論1</b></p><p>  1.1 課題背景1</p><p>  1.2 研究意義1</p&

13、gt;<p>  1.3 國內(nèi)外研究現(xiàn)狀2</p><p>  1.3.1 國外研究現(xiàn)狀2</p><p>  1.3.2 國內(nèi)研究現(xiàn)狀3</p><p>  1.4 本論文的主要研究內(nèi)容4</p><p>  1.5 論文結(jié)構(gòu)4</p><p>  2 相關(guān)技術(shù)介紹與研究6</p>

14、;<p>  2.1 SDN網(wǎng)絡(luò)架構(gòu)6</p><p>  2.2 Openflow技術(shù)原理7</p><p>  2.2.1 概述7</p><p>  2.2.2 OpenFlow交換機8</p><p>  2.2.3 OpenFlow 協(xié)議10</p><p>  2.3 Mininet

15、的解析12</p><p>  2.3.1 Mininet的概述12</p><p>  2.3.2 Mininet的使用13</p><p>  2.3.3 Mininet的結(jié)構(gòu)分析13</p><p>  2.4 Opendaylight的應(yīng)用15</p><p>  2.4.1 Opendaylight

16、 概述15</p><p>  2.4.1 Opendaylight 項目架構(gòu)16</p><p>  2.5 本章小結(jié)17</p><p>  3 基于SDN網(wǎng)絡(luò)框架設(shè)計18</p><p>  3.1 拓撲的設(shè)計18</p><p>  3.1.1 通過Mininet命令行實現(xiàn)18</p>

17、<p>  3.1.2 通過python腳本設(shè)計拓撲19</p><p>  3.1.3 通過python程序自定義拓撲20</p><p>  3.2 流表的下發(fā)22</p><p>  3.3 驗證功能的開發(fā)24</p><p>  3.3.1 拓撲的準確性校驗24</p><p>  3.3

18、.2 網(wǎng)絡(luò)性能的測試24</p><p>  3.3.3 轉(zhuǎn)發(fā)路徑的驗證性功能的設(shè)計25</p><p>  3.5 本章小結(jié)25</p><p>  4 基于SDN環(huán)境的通信網(wǎng)絡(luò)的實現(xiàn)26</p><p>  4.1 實驗環(huán)境的搭建26</p><p>  4.1.1 Mininet的安裝26</p

19、><p>  4.1.2 Opendaylight 的安裝 27</p><p>  4.2 通信網(wǎng)絡(luò)測試30</p><p>  4.2.1 實驗130</p><p>  4.2.2 實驗231</p><p>  4.2.3 實驗335</p><p>  4.2.4 實驗437

20、</p><p>  4.2.5 實驗543</p><p>  4.3 本章小結(jié)45</p><p>  5 總結(jié)與展望46</p><p>  5.1 工作總結(jié)46</p><p><b>  5.2 展望46</b></p><p><b>  致

21、 謝47</b></p><p><b>  參考文獻48</b></p><p><b>  1 緒論</b></p><p><b>  1.1 課題背景</b></p><p>  在傳統(tǒng)的路由器或交換機設(shè)計中,快速的報文轉(zhuǎn)發(fā)(數(shù)據(jù)面)和高層路由決定(控

22、制面)是集成在一起的,傳統(tǒng)網(wǎng)絡(luò)一開始就是一個分布式的格局,沒有中心的控制節(jié)點,網(wǎng)絡(luò)中的設(shè)備之間都是相互傳遞路由信息,由每臺設(shè)備自己決定轉(zhuǎn)發(fā)規(guī)則,這直接導(dǎo)致了沒有整體觀念,不能從整個網(wǎng)絡(luò)的角度對流量進行調(diào)控。并且一個大型網(wǎng)絡(luò)的設(shè)計都是基于傳統(tǒng)的網(wǎng)絡(luò)設(shè)計架構(gòu),在網(wǎng)絡(luò)項目的實施過程中都是基于具體的交換機和路由器進行相應(yīng)的配置,通常一些學(xué)校,醫(yī)院或者政府部門的大型網(wǎng)絡(luò)項目牽扯到的網(wǎng)絡(luò)設(shè)備達到上千臺,因此大型網(wǎng)絡(luò)項目的實施與維護都越來越復(fù)雜。在近

23、幾十年的網(wǎng)絡(luò)技術(shù)發(fā)展過程中,由于這種緊耦合大型主機式的發(fā)展限制了IP網(wǎng)絡(luò)創(chuàng)新技術(shù)的出現(xiàn),更多的是通過不斷增長的RFC文檔對現(xiàn)行網(wǎng)絡(luò)進行修修補補,造成了交換機/路由器設(shè)備控制功能高度復(fù)雜。</p><p>  軟件定義網(wǎng)絡(luò)SDN[1](Soft-ware Defined Networking)是由美國的Clean State研究組提出來的一種新型的網(wǎng)絡(luò)架構(gòu),2006年美國斯坦福大學(xué)的學(xué)生Casado開展了一個關(guān)于網(wǎng)

24、絡(luò)安全與管理的項目Ethane[2],該項目通過一個集中式的控制器,使網(wǎng)絡(luò)管理員能夠在各種網(wǎng)絡(luò)設(shè)備中定義基于網(wǎng)絡(luò)流的安全策略,后來Casado和他的導(dǎo)師McKeown發(fā)現(xiàn)如果將Ethane設(shè)計應(yīng)用于一般化,不僅局限于安全方面,即將傳統(tǒng)網(wǎng)絡(luò)的控制平面和數(shù)據(jù)平面分離,通過集中式的控制器用標準化的接口來對各種網(wǎng)絡(luò)設(shè)備進行管理和配置,這也是SDN的核心思想,如此一來,將為網(wǎng)絡(luò)資源的設(shè)計、管理和使用提供更多的可能性,從而革命性的改變了現(xiàn)有的網(wǎng)絡(luò)架

25、構(gòu),為未來的網(wǎng)絡(luò)發(fā)展提供了一個新的方向?;贠penFlow[3]的SDN技術(shù)推出后。2009年被MIT評為十大前沿技術(shù)[4]。</p><p><b>  1.2 研究意義</b></p><p>  SDN在最近幾年發(fā)展愈發(fā)被看重,隨著各家廠商,運營商等的加入,各項</p><p>  也逐漸趨于成熟,無論在對企業(yè),網(wǎng)絡(luò)工程師,還是網(wǎng)絡(luò)本身

26、架構(gòu)來說,它都有不小的優(yōu)勢。</p><p>  對于企業(yè)來說來說,會大大較小網(wǎng)絡(luò)設(shè)備的購買以及后期維護的費用,因為在傳統(tǒng)網(wǎng)絡(luò)架構(gòu)中,路由器,交換機,防火墻等是構(gòu)成網(wǎng)絡(luò)的不可獲取的主要元</p><p>  素,而這些元素在SDN的架構(gòu)中會被替代成Openflow 交換機和控制器,顯然控制器不需要像傳統(tǒng)網(wǎng)絡(luò)中的路由器數(shù)量那么龐大,同時后期的設(shè)備的維護數(shù)量也相應(yīng)的減少了,對應(yīng)的維護費用也減少

27、了。</p><p>  對于網(wǎng)絡(luò)項目的實施人員來說,由于在SDN架構(gòu)中,交換機只負責簡單的轉(zhuǎn)發(fā)工作,而主要的流表下發(fā)都是有控制器完成的,所以也大大簡化了網(wǎng)絡(luò)工程師的配置工作,顯然已經(jīng)不需要再像傳統(tǒng)網(wǎng)絡(luò)中那樣到每臺路由器上配置有路由協(xié)議,做策略,到每臺交換機上配置vlan等信息,因此配置工作也大大減少,網(wǎng)絡(luò)項目的實施效率也會對應(yīng)的提高。</p><p>  對于網(wǎng)絡(luò)架構(gòu)本身來講,傳統(tǒng)網(wǎng)絡(luò)新

28、業(yè)務(wù)的部署方式是補丁式的,因為網(wǎng)絡(luò)中新老設(shè)備并存,新業(yè)務(wù)必須兼容老業(yè)務(wù),新的協(xié)議基本上都是在原有協(xié)議的基礎(chǔ)上進行擴展,這就大大限制了網(wǎng)絡(luò)架構(gòu)創(chuàng)新性的發(fā)展。而在SDN網(wǎng)絡(luò)架構(gòu)中用戶不僅可以通過控制器來控制底層交換機的轉(zhuǎn)發(fā)行為,甚至可以按需定義報文的封裝格式,而不再局限于Mac,ip等元素,這也為SDN網(wǎng)絡(luò)架構(gòu)的創(chuàng)新帶來了無限的可能性。</p><p>  1.3 國內(nèi)外研究現(xiàn)狀</p><p&g

29、t;  SDN作為近幾年新興起來的技術(shù),由于它具有創(chuàng)新性高,引入新業(yè)務(wù)速度快,網(wǎng)絡(luò)維護費用低,可以和虛擬化技術(shù)結(jié)合等優(yōu)勢,因此得到很多廠商,運營商的青睞,并且也有專門為之成立的組織機構(gòu),最近幾年在各方的努力下SDN的實踐化應(yīng)用也逐漸有了進步。</p><p>  1.3.1 國外研究現(xiàn)狀 </p><p>  a. 開放式網(wǎng)絡(luò)基金會ONF[5](Open Networking Founda

30、tion)已經(jīng)完成了SDN的架構(gòu)定義、安全需求和原則、光傳送SDN需求,遷移需求等多個文檔,并完成了南向接口協(xié)議Openflow1.4.x和配置管理協(xié)議OF-Config1.2的指定,在ONF發(fā)布的最新的SDN Architecture中,在三層架構(gòu)的基礎(chǔ)上還增加了管理能力和多個信區(qū)域,ONF成立了Carrire SDN討論組,針對運營商網(wǎng)絡(luò)在SDN領(lǐng)域的特有需求進行討論[6]。</p><p>  b. 國際互

31、聯(lián)網(wǎng)工程任務(wù)組IETF(The Internet Engineering Task Force )</p><p>  中的PCE(Path Computation Element)工作組正在推進有狀態(tài)PCE的標準化,以提供實時流量工程計算中的路徑計算元素和網(wǎng)絡(luò)節(jié)點間的相關(guān)協(xié)議,I2RS(Interface to the routing system)通過制定I2RS協(xié)議實現(xiàn)控制器和網(wǎng)絡(luò)設(shè)備的交互,類似于ONF中

32、的openflow協(xié)議[7]。</p><p>  c. OpenDaylight[8]是有l(wèi)inux基金會提出了一個項目,正在開展的項目包括控制器,虛擬用戶網(wǎng)絡(luò),適用于SDN的SNMP等。ODL已經(jīng)發(fā)布了第一個通用平臺Hydrogen,包括基礎(chǔ)版,運營商版,和虛擬化3個版本,并且已經(jīng)開啟了下一個平臺Helium的工作,同是ODL已經(jīng)開放了通用的北向接口,只需在Openstake中內(nèi)置一個Neutron插件,就可

33、與之結(jié)合,大大簡化了對Opendstake的要求,加快了控制器與業(yè)務(wù)層的適配。</p><p>  d. 斯坦福大學(xué)的研究者在2008年提出了基于OpenFlow,它作為SDN的原型實現(xiàn)方式,代表著SDN控制轉(zhuǎn)發(fā)分離技術(shù)的實現(xiàn),隨著SDN技術(shù)得到認可,從嚴格意義上來講,OpenFlow指的是SDN控制平面和數(shù)據(jù)平面之間多種通信協(xié)議之一,但實際上OpenFlow以其良好的靈活性、規(guī)范性已被看做SDN通信協(xié)議事實上的

34、標準。</p><p>  e. 日本NTT是較早進行SDN技術(shù)研究的運營商之一,研發(fā)了一款虛擬網(wǎng)絡(luò)控制器,用于多個數(shù)據(jù)中心的統(tǒng)一服務(wù)和按需分配,已經(jīng)部署到其位于歐洲,美國和日本的數(shù)據(jù)中心。</p><p>  f. 谷歌構(gòu)建的B4網(wǎng)絡(luò)是目前最著名最有影響力的SDN技術(shù)應(yīng)用案例,它由中心流量工程(TE)服務(wù)器,網(wǎng)絡(luò)控制服務(wù)器(NCS),以及下層的交換機組成,在網(wǎng)絡(luò)控制服務(wù)器上運行OpenF

35、low Controller(OFC)集群,交換機硬件運行OpenFlow Agent接受OFC的控制。根據(jù)OFC下發(fā)的流表轉(zhuǎn)發(fā)流量,谷歌基于OpenFlow理念搭建的數(shù)據(jù)中心Wan網(wǎng)絡(luò)可通過編程實現(xiàn)自動創(chuàng)建和重新配置遍布全球的數(shù)據(jù)中心之間的連接,通過周密的流量工程和優(yōu)先級次序的工作方式使其資源利用率從30%提升到了90%以上,極大的節(jié)省了成本[9]。</p><p>  g. 針對南向接口,除了ONF提出的Op

36、enFlow協(xié)議和OF-CONFIG[10]協(xié)議外,IETF提出了For-CES[11]協(xié)議,思科公司提出了OnePK[12]協(xié)議。ForCES對網(wǎng)絡(luò)設(shè)備內(nèi)部結(jié)構(gòu)重新定義,將轉(zhuǎn)發(fā)元素和控制元素分離,形成兩個獨立的邏輯實體,兩個邏輯實體件靠ForCES協(xié)議通信。OnePK則是cisco針對SDN產(chǎn)品專門開發(fā)的接口協(xié)議,該協(xié)議可以運行在cisco所研發(fā)的專屬平臺上,并支持開發(fā)者用C或JAVA編寫的程序。</p><p&g

37、t;  1.3.2 國內(nèi)研究現(xiàn)狀</p><p>  a. 目前我國的通信標準化協(xié)會(CCSA)也與時俱進,在國內(nèi)主導(dǎo)SDN的標準化工作,其中在TC3下特設(shè)了SVN(Software Virtualization Network)研究組,目前重點在基于SDN的智能管道技術(shù)和基于虛擬化的核心網(wǎng)的研究。</p><p>  b. 中國電信成立了集團級的云計算重點實驗室,以云數(shù)據(jù)中心為切入點,探

38、索SDN技術(shù),利用SDN技術(shù)+NFV[13]技術(shù)提供面向云計算服務(wù)的網(wǎng)絡(luò)增值業(yè)務(wù),其中,中國電信股份有限公司北京研究院還自主研發(fā)控制器等SDN的核心組件。</p><p>  c. 中國移動已經(jīng)在國內(nèi)、北美兩地開展了2次大規(guī)模測試,針對7個廠家的控制器,10個廠家的OpenFlow交換機搭建測試環(huán)境,進行OpneFlow標準,功能、性能、SDN應(yīng)用等測試,驗證標準及產(chǎn)品成熟度并聯(lián)合芯片廠家研發(fā)了Super PTN

39、芯片,成功演示了基于OpenFlow的SDN化PTN圓形系統(tǒng)。</p><p>  d. 騰訊在第二屆SDN & NFV大會上提出了構(gòu)建邊緣智能網(wǎng)絡(luò)的概念,該網(wǎng)絡(luò)基于Overlay的SDN實現(xiàn)方式,將虛擬網(wǎng)絡(luò)與物理網(wǎng)絡(luò)解耦,虛擬機通過開源OVS接入網(wǎng)絡(luò)OVS根據(jù)上層的分布式控制器下發(fā)流表轉(zhuǎn)發(fā)流量,虛擬網(wǎng)絡(luò)之間使用VXVLAN標簽實現(xiàn)用戶隔離,這種使用OVS+VXVLAN+SDN構(gòu)建的虛擬擴往遷移,虛擬二層

40、網(wǎng)絡(luò)進行伸縮,多租戶安全隔離,業(yè)務(wù)靈活擴展,流量只能調(diào)度等,能有效提高數(shù)據(jù)中心間的寬帶利用率,減少故障收斂時間,從而提升用戶體驗[14]。</p><p>  e. 華為也在SDN方向進行了探索,基于SDN的虛擬感知解決方案,控制層采用SDN控制器,數(shù)據(jù)層采用OpenFlow交換機,應(yīng)用層開放兼容多個云平臺--OpenStake,VMware,微軟數(shù)據(jù)中心等;高性能的NVO3網(wǎng)關(guān);PCE提升廣域網(wǎng)鏈路利用效率等。

41、華為不僅在實踐中敢于實踐,在技術(shù)創(chuàng)新方面OF控制器,SmartTE演示系統(tǒng),SDN的設(shè)備技術(shù)研究等領(lǐng)域都取得了相應(yīng)的成績[15]。</p><p>  1.4 本論文的主要研究內(nèi)容</p><p>  自從SDN技術(shù)被提出來之后,由于本身所具有的相對于傳統(tǒng)網(wǎng)絡(luò)的優(yōu)勢,因此迅速得到了各廠商,運營商的認可,并且已經(jīng)成立了一些專門為之服務(wù)的機構(gòu),他們負責定義相關(guān)協(xié)議的標準,比如openflow

42、1.0,openflow 1.3等協(xié)議也逐一問世。</p><p>  本文正是在這種研究氛圍如此濃厚的情況下,研究了SDN網(wǎng)絡(luò)架構(gòu)的以下內(nèi)容:</p><p> ?。?)基礎(chǔ)設(shè)施層和控制器之間的拓撲驗證問題,由于SDN是一項新型的的技術(shù),所以有關(guān)SDN的產(chǎn)品都是比較昂貴的,因此本論文的實驗環(huán)境都是基于虛擬機來實現(xiàn)的,在基礎(chǔ)設(shè)施層主要由Mininet構(gòu)成,當Mininet將所需要的拓撲搭建

43、完成后,我們需要驗證Mininet的拓撲是否在Opendaylight控制器里正常顯示,所以這就需要在Mininet端使用net命令查看Mininet的拓撲是否正確創(chuàng)建,在正確創(chuàng)建的前提下,并且調(diào)用拓撲和連接Opendaylight的命令都無誤的情況下,拓撲驗證才能成功。</p><p> ?。?)轉(zhuǎn)發(fā)路徑的驗證問題,在本系統(tǒng)中,路徑的轉(zhuǎn)發(fā)都是基于控制住器下發(fā)流表來實現(xiàn)的,因為需要模擬真實環(huán)境,所以就要確保流量準

44、確無誤的按照下發(fā)的流表來執(zhí)行,本系統(tǒng)利用流表項中的n_packets來驗證流表下發(fā)是否生效。</p><p> ?。?)基于跳數(shù)的轉(zhuǎn)發(fā)路徑研究,將SDN網(wǎng)絡(luò)架構(gòu)和傳統(tǒng)網(wǎng)絡(luò)架構(gòu)里的RIP協(xié)議相比較,分別從不同的角度來演示說明了SDN網(wǎng)絡(luò)機構(gòu)在對拓撲的把握,以及轉(zhuǎn)發(fā)路徑的選取上都有不小的優(yōu)勢。</p><p> ?。?)基于帶寬的轉(zhuǎn)發(fā)路徑的研究,在實際環(huán)境中,鏈路總體帶寬雖然不變,但是隨著業(yè)務(wù)

45、需求的增加,分配給每個用戶的帶寬可能就會不足,因此本實驗通過模擬應(yīng)用層動態(tài)感知網(wǎng)絡(luò)拓撲的帶寬變化,靈活分配流量所走的路徑,來達到流量時刻保持高速轉(zhuǎn)發(fā)的目的。</p><p><b>  1.5 論文結(jié)構(gòu)</b></p><p>  本論文的主要分為五章,每章的研究內(nèi)容如下:</p><p>  第一章為緒論,首先介紹了課題的研究背景,以及研究意

46、義,然后介紹了國內(nèi)外關(guān)于SDN的一些研究進展,最后介紹了本論文的研究內(nèi)容和論文結(jié)構(gòu)。</p><p>  第二章為相關(guān)技術(shù)的研究,本章首先介紹了SDN網(wǎng)絡(luò)架構(gòu),它主要分為基礎(chǔ)設(shè)施層,控制層,以及應(yīng)用層,并且介紹了每層的功能,然后詳細分析了南向接口協(xié)議Openflow ,最后介紹了實驗環(huán)境所需要的兩大組件,Mininet和Opendaylight。</p><p>  第三章為系統(tǒng)的設(shè)計,首

47、先介紹了拓撲的三種搭建方法,包括用Mininet命令行,Python腳本以及Python程序。然后介紹了利用了控制器進行流表下發(fā)的過程,最后介紹了拓撲的驗證,轉(zhuǎn)發(fā)路徑的驗證,已經(jīng)網(wǎng)絡(luò)性能的檢測。</p><p>  第四章為系統(tǒng)的實現(xiàn),本章首先介紹了實驗環(huán)境的搭建包括Mininet的安裝以及Opendaylight的安裝,然后在SDN環(huán)境下進行了通信網(wǎng)絡(luò)的測試包括基于拓撲信息的獲取功能,拓撲結(jié)構(gòu)的驗證功能,控制轉(zhuǎn)

48、發(fā)路徑功能,基于跳數(shù)的路徑選擇,基于帶寬的路徑選擇。</p><p>  第五章為結(jié)束語,本章首先對該論文進行了總結(jié),然后對SDN的未來進行了展望。</p><p>  2 相關(guān)技術(shù)介紹與研究</p><p>  2.1 SDN網(wǎng)絡(luò)架構(gòu)</p><p>  ONF標準化組織在提出的基于開放的Openflow南向接口協(xié)議的SDN架構(gòu),其核心理念

49、是將傳統(tǒng)網(wǎng)絡(luò)的控制平面和數(shù)據(jù)平面分離,通過集中式的控制器用標準化的接口來對各種網(wǎng)絡(luò)設(shè)備進行管理和配置 。如圖2.1所示,它由下至上分為基礎(chǔ)設(shè)施層,控制層,應(yīng)用層。 </p><p>  圖 2.1 SDN框架圖</p><p>  基礎(chǔ)設(shè)施層主要由通用的轉(zhuǎn)發(fā)設(shè)備構(gòu)成?;诳刂茖酉掳l(fā)的指令和策略進行分組的轉(zhuǎn)發(fā)??刂茖优c轉(zhuǎn)發(fā)設(shè)備之間的接口被稱為Openflow。通用轉(zhuǎn)發(fā)設(shè)備的報文轉(zhuǎn)發(fā)采用三態(tài)

50、內(nèi)容尋址存儲器(Ternary Content Addressable Memory,TCAM)、現(xiàn)場可編程門陣列(Field-Programmable Gate Array,F(xiàn)PGA)等專用集成電路實現(xiàn),以充分發(fā)揮硬件性能優(yōu)勢。NEC、Juniper、HP、Cisco都在推進支持Openflow接口的原型及產(chǎn)品。</p><p>  控制層主要由控制軟件構(gòu)成,它是將原有的交換機、路由器等網(wǎng)絡(luò)設(shè)備中的控制功能抽取

51、出來并與獨立的軟件結(jié)合起來從而形成控制軟件。原有的交換機、路由器中的STP、RIP、IS-IS等軟件功能都從基礎(chǔ)設(shè)施層剝離,由控制層統(tǒng)一實施交換與路由的管理??刂栖浖梢允占W(wǎng)絡(luò)狀態(tài)信息并遠程向轉(zhuǎn)發(fā)設(shè)備下發(fā)靈活多變的流表(flow table)和組表(group table),實現(xiàn)對網(wǎng)絡(luò)報文的處理,如轉(zhuǎn)發(fā)、標簽處理、過濾等。現(xiàn)在業(yè)界已經(jīng)出現(xiàn)一些開源控制器軟件—Opendaylight,Ryu,Pox,F(xiàn)loodlight等等</p

52、><p>  應(yīng)用層由軟件形態(tài)的應(yīng)用程序構(gòu)成,可通過Restful API的方式或者網(wǎng)絡(luò)操作系統(tǒng)API的方式調(diào)用控制層提供的控制網(wǎng)絡(luò)轉(zhuǎn)發(fā)面的能力。比如,應(yīng)用可以直接要求控制層為它提供端到端的路由及QoS保障,也可以通過控制層對網(wǎng)絡(luò)進行精細化的管理,比如設(shè)置特殊的訪問控制策略、負載均衡方案、防火墻設(shè)置規(guī)則等。</p><p>  其中層與層之間的通信是通過相應(yīng)的接口來完成,其中基礎(chǔ)設(shè)施層通過南向

53、接口和控制層來溝通,Openflow協(xié)議就是比較典型的南向接口協(xié)議。而控制層和應(yīng)用層之間通過北向接口協(xié)議來進行通信,到目前為止還沒有統(tǒng)一的北向接口標準協(xié)議。</p><p>  總體來說,SDN網(wǎng)絡(luò)結(jié)構(gòu)層次化明顯,通過對網(wǎng)絡(luò)設(shè)備的集中化控制,控制層能夠根據(jù)全局網(wǎng)絡(luò)信息合理高效的分配網(wǎng)絡(luò)流量,通過開放的控制接口,能夠?qū)崿F(xiàn)控制層對網(wǎng)絡(luò)設(shè)備的靈活控制。同時,用戶也可以對開放接口進行自定義編程,這也提高了網(wǎng)絡(luò)的創(chuàng)新能力。

54、</p><p>  2.2 Openflow技術(shù)原理</p><p><b>  2.2.1 概述</b></p><p>  OpenFlow是由斯坦福大學(xué)的Nick McKeown教授在2008年4月ACM Commun-ications Review上發(fā)表的一篇論文OpenFlow: enabling innovation in cam

55、-pus networks首先詳細論述了OpenFlow的原理,最初出發(fā)點是用于校園內(nèi)網(wǎng)絡(luò)研究人員實驗其創(chuàng)新網(wǎng)絡(luò)架構(gòu)、協(xié)議,考慮到實際的網(wǎng)絡(luò)創(chuàng)新思想需要在實際網(wǎng)絡(luò)上才能更好地驗證,而研究人員又無法修改在網(wǎng)的網(wǎng)絡(luò)設(shè)備,故而提出了OpenFlow的控制轉(zhuǎn)發(fā)分離架構(gòu),將控制邏輯從網(wǎng)絡(luò)設(shè)備盒子中引出來,研究者可以對其進行任意的編程從而實現(xiàn)新型的網(wǎng)絡(luò)協(xié)議、拓撲架構(gòu)而無需改動網(wǎng)絡(luò)設(shè)備本身。自2009年底發(fā)布第一個用于商業(yè)化交換機的正是標準1.0版本

56、以后,OpenFlow協(xié)議已經(jīng)經(jīng)歷了1.1、1.2、1.3以及1.4等版本的演進變化過程。表2.1列出了OpenFlow協(xié)議各個版本的演進過程和主要變化。</p><p>  表 2.1 Openflow協(xié)議各個版本介紹</p><p>  2.2.2 OpenFlow交換機</p><p>  Openflow交換機是整個OpenFlow網(wǎng)絡(luò)的核心部件之一,如圖2

57、.2所示,openflow交換機結(jié)構(gòu)主要由安全通道,流表,Openflow協(xié)議組成。它主要描述了控制層以下,基礎(chǔ)設(shè)施層以上之間的標準,其中控制層和基礎(chǔ)設(shè)施層之間通過加載在安全通道里的Openflow協(xié)議進行通信。</p><p>  圖 2.2 OpenFlow交換機的構(gòu)成</p><p>  Openflow交換機接收到的數(shù)據(jù)包通過查詢流表來取得相應(yīng)的動作,如果沒有匹配的表象,則把數(shù)據(jù)

58、包發(fā)送給控制器,由控制器決定轉(zhuǎn)發(fā)行為。安全通道是交換機和控制器之間同行的接口,控制器通過這個接口控制和管理交換機,同時控制器接受來自交換機的時間并向交換機發(fā)送數(shù)據(jù)包。Openflow協(xié)議是指控制器和交換機之間通信的標準。</p><p>  Openflow交換機接受到一個數(shù)據(jù)包時,首先從Flowtable0開始按照優(yōu)先級進行匹配查找,如果匹配成功,將首先更新該規(guī)則對應(yīng)的計數(shù)器(如果匹配數(shù)據(jù)包總數(shù)目和總字節(jié)數(shù)等)

59、,然后執(zhí)行對應(yīng)的指令集和,比如跳轉(zhuǎn)至后續(xù)某一FlowTable繼續(xù)處理,修改或者立即自行該數(shù)據(jù)包對應(yīng)的Action Set等,如果匹配不成功,則根據(jù)流表中的配置進行相應(yīng)的處理,比如發(fā)送給控制器,丟包,護著繼續(xù)比對下一個流表項。</p><p>  傳統(tǒng)的網(wǎng)絡(luò)設(shè)備的架構(gòu)中包含兩個方面,控制面和轉(zhuǎn)發(fā)面。轉(zhuǎn)發(fā)平面包含三個功能,轉(zhuǎn)發(fā)決策、背板和輸出鏈路調(diào)度、通常采用專門的設(shè)計的ASIC芯片實現(xiàn)性能的提升,轉(zhuǎn)發(fā)平面相對于控

60、制平面具有更高的使用頻率,參考如圖 2.3所示。</p><p>  圖 2.3 傳統(tǒng)網(wǎng)絡(luò)交換設(shè)備的架構(gòu)示意圖</p><p>  SDN交換機的實現(xiàn)還需要考慮到使用場景的需要,從而合理的將控制平面和轉(zhuǎn)發(fā)平面進行分離??偟膩碚f。以下四個因素是決定不同場景下的SDN交換機的實現(xiàn)的關(guān)鍵性因素。</p><p><b>  a. 交換模式</b>&l

61、t;/p><p>  交換模式是決定是決定傳輸?shù)膱笪脑谵D(zhuǎn)發(fā)時被處理的時間的關(guān)鍵,因為決策層面已經(jīng)被分離出去了,低延遲,高性能,可靠性是實際應(yīng)用常見的需求。相比與傳統(tǒng)的轉(zhuǎn)發(fā)方式,SDN交換機中由于已經(jīng)將轉(zhuǎn)發(fā)和控制分離,減輕了交換機在轉(zhuǎn)發(fā)延遲上的負擔,所以交換機在轉(zhuǎn)發(fā)時應(yīng)著重考慮到可靠性的問題,所以采用存儲轉(zhuǎn)發(fā)模式是最好的選擇。</p><p><b>  b. 背板設(shè)計</b&g

62、t;</p><p>  交換機的背板為數(shù)據(jù)段的傳送提供了通道,傳統(tǒng)的交換機背板哈含有決策轉(zhuǎn)發(fā)硬件輔助設(shè)備。由于共享總線方式會出現(xiàn)共享總線的速度對整個網(wǎng)絡(luò)的流量產(chǎn)生產(chǎn)生很大的影響的缺點,所以SDN交換機的實現(xiàn)應(yīng)該引入交叉開關(guān)矩陣機制,以避免因為仲裁器的決策導(dǎo)致數(shù)據(jù)包吃遲遲無法從端口發(fā)送出去,保證數(shù)據(jù)交換的概率,進一步提升SDN交換機轉(zhuǎn)發(fā)工作效率。</p><p><b>  c.

63、 緩沖機制</b></p><p>  當入端口的速率和出端口的速率不匹配時,數(shù)據(jù)包不能及時的被發(fā)送出去,一次SDN交換機和傳統(tǒng)交換機設(shè)備相同,都必須考慮數(shù)據(jù)包的緩沖問題,由于SDN交換機轉(zhuǎn)發(fā)面的速率比傳統(tǒng)交換機高得多,需要重點考慮數(shù)據(jù)擁塞時的交換機處理方法,數(shù)據(jù)幀很有可能被丟棄這種后果對SDN系統(tǒng)來說可能是非常致命的,參考傳統(tǒng)緩沖機制。SDN交換機可以考慮一下兩種緩沖機制:</p>&

64、lt;p> ?。?)端口緩沖,交換機在接收數(shù)據(jù)包時,利用緩沖區(qū)域進行緩沖,當緩沖區(qū)</p><p>  滿時,后續(xù)收到的數(shù)據(jù)將被丟棄如果緩沖區(qū)域可以靈活調(diào)整,則可以避</p><p>  免因為緩沖區(qū)域使用殆盡而造成的包丟失。</p><p> ?。?)共享內(nèi)存,即所有端口可以共享內(nèi)存空間,通過動態(tài)訪問內(nèi)存池,可以 </p><p&g

65、t;  保證數(shù)據(jù)緩沖由端口流量所控制。</p><p>  由于中心交換機需要處理大量的數(shù)據(jù),使用端口緩沖不可避免的會出現(xiàn)緩沖容量不足的情況,為了保證數(shù)據(jù)的可靠性,SDN交換機在設(shè)計實現(xiàn)的時候應(yīng)該采用共享內(nèi)存的緩沖機制。</p><p><b>  d. 轉(zhuǎn)發(fā)策略</b></p><p>  在緩沖區(qū)的數(shù)據(jù)包需要根據(jù)轉(zhuǎn)發(fā)策略來進行轉(zhuǎn)發(fā),數(shù)據(jù)的轉(zhuǎn)

66、發(fā)可以采用不同的策略來決定,傳統(tǒng)的交換機根據(jù)路由表和轉(zhuǎn)發(fā)表來決定數(shù)據(jù)包的轉(zhuǎn)發(fā)方向,而SDN交換機同樣需要這種轉(zhuǎn)發(fā)決策機制,SDN交換機在進行轉(zhuǎn)發(fā)時所需要的信息一方面是對傳統(tǒng)網(wǎng)絡(luò)各層次信息的綜合,一方面也容易由控制器記性管理使得轉(zhuǎn)發(fā)更加靈活。</p><p>  2.2.3 OpenFlow 協(xié)議</p><p>  OpenFlow規(guī)范主要分為如下3大部分,</p><

67、p>  a. Openflow的端口(port)</p><p>  Openflowguifan將Openflow交換機的端口分為以下3中類型:</p><p>  (1)物理端口,即設(shè)備上物理可見的端口</p><p> ?。?)邏輯端口,在物理端口基礎(chǔ)上由交換機設(shè)備抽象出來的端口</p><p> ?。?)保留接口:由轉(zhuǎn)發(fā)動作定義

68、的接口嗎,實現(xiàn)Openflow轉(zhuǎn)發(fā)功能,除 </p><p>  Any接口外其他接口進可作為出接口</p><p>  b. Openflow的FlowTable(流表)</p><p>  在Openflow 1.0中,每個流表由多個流標項組成,每個流標項由包頭域,計數(shù)器,動作三部分組成。</p><p>  在Openflow 1.0中

69、包頭域有12個元素來匹配數(shù)據(jù)流,如圖2.3,端口號、VLAN、L2/L3/L4信息等,但是每個字段都是可以通配的,網(wǎng)絡(luò)的運營商可以決定使用何種粒度的流,比如運營商只需要根據(jù)目的IP進行路由,那么流表中就可以只有目的IP字段是有效的,其它全為通配。</p><p>  圖 2.4 Openflow1.0匹配項目</p><p>  每個表項對應(yīng)到0個或者多個動作,如果沒有轉(zhuǎn)發(fā)(forward

70、)行動,則默認丟棄。多個動作的執(zhí)行需要依照行動列表中優(yōu)先級順序依次進行。動作可以分為兩種類型:必備動作(Required Actions)和可選動作(Optional Actions)。必備動作是默認支持的,交換機在連接到控制器時需要通知控制器它支持的可選動作。交換機將會對包頭域匹配到的數(shù)據(jù)包執(zhí)行相應(yīng)的動作。</p><p>  計數(shù)器可以針對每張表、每個流、每個端口、每個隊列來分別統(tǒng)計。通過對活躍的表項數(shù),查詢

71、次數(shù),匹配流的個數(shù),收到的數(shù)據(jù)包數(shù)目等信息的收集,這樣一來,使得網(wǎng)絡(luò)的管理和維護都變得更加容易。</p><p>  c. Openflow的通信通道</p><p>  Openflow規(guī)范定義了一個OpenFlow交換機如何與控制器連接、通信以及相關(guān)消息類型等。Openflow協(xié)議支持三種消息類型:controller-to-switch(表2.2),Asynchronous(表2.3

72、)和symmetric(表2.4),每一類消息又有多個子消息類型。Controlle-r-to-switch消息由控制器發(fā)起,用來管理或獲取switch狀態(tài);asynchronous消息由switch發(fā)起,用來將網(wǎng)絡(luò)事件或交換機狀態(tài)變化更新到控制器;symme-tric消息可由交換機或控制器發(fā)起。</p><p>  表 2.2 Controller-to-switch子消息類型</p><

73、;p>  表 2.3 Asynchronous 子消息類型</p><p>  表 2.4 Symmertic子消息類型</p><p>  2.3 Mininet的解析</p><p>  2.3.1 Mininet的概述</p><p>  Mininet是斯坦福大學(xué)Nick McKeown 小組基于linux Containe

74、r架構(gòu)開發(fā)的一個輕量級的軟件定義網(wǎng)絡(luò)的研發(fā)和測試的平臺,該系統(tǒng)由虛擬的終端節(jié)點,OpenFlow交換機,控制器組成,因此它可以模擬真實的網(wǎng)絡(luò)。它采用輕量級的虛擬化技術(shù)使一個單一的系統(tǒng)看起來像一個完整的網(wǎng)絡(luò)的內(nèi)核系統(tǒng)和用戶代碼,也可簡單理解為SDN網(wǎng)絡(luò)系統(tǒng)中的一種基于進程虛擬化平臺,它支持OpenFlow、Open vSwith 等各種協(xié)議,Mininet也可以模擬一個完整的網(wǎng)絡(luò)主機、鏈接和交換機在同一臺計算機上且有助于互動開發(fā)、測試和演

75、示,尤其是那些使用OpenFlow和SDN技術(shù);同時也可將此進程虛擬化的平臺下的代碼遷移到真實的環(huán)境中。</p><p>  Mininet的關(guān)鍵特性和優(yōu)勢如下:</p><p>  a. Mininet能夠創(chuàng)建由虛擬的主機,交換機和控制器構(gòu)成的網(wǎng)絡(luò)。</p><p>  b. Mininet主機運行標準的linux網(wǎng)絡(luò)軟件,其交換機支持OpenFlow???lt;

76、/p><p>  以認為Mininet是一個用于開發(fā)OpenFlow應(yīng)用的低成本的實驗環(huán)境,</p><p>  不需要實際布線搭建物理網(wǎng)絡(luò),就能夠?qū)?fù)雜的網(wǎng)絡(luò)拓撲進行測試。</p><p>  c. 提供了強大的命令行接口(command-line interface),CLI支持Openflow </p><p>  協(xié)議并能感知網(wǎng)絡(luò)拓撲結(jié)構(gòu)

77、,可以在整個范圍內(nèi)進行調(diào)試。</p><p>  d. 提供簡單可擴展的python API,通過該API開發(fā)者可方便的創(chuàng)建網(wǎng)絡(luò)</p><p><b>  和對網(wǎng)絡(luò)進行試驗。</b></p><p>  e. 允許多個開發(fā)者在同一個網(wǎng)絡(luò)拓撲環(huán)境下協(xié)同試驗。</p><p>  f. 便于安裝,良好的硬件移植性。<

78、/p><p>  2.3.2 Mininet的使用</p><p>  Mininet采用Python語言開發(fā),能夠簡單快速的創(chuàng)建一個Openflow網(wǎng)絡(luò)系統(tǒng),并與該系統(tǒng)進行交互和共享,可以使用Mininet的命令行來創(chuàng)建網(wǎng)絡(luò),利用其命令行能夠便于開發(fā)者使用命令的方式控制和管理整個虛擬網(wǎng)絡(luò),此外還可以利用Mininet提供的API自定義網(wǎng)絡(luò)拓撲結(jié)構(gòu)。在Mininet中常用的命令如下:</

79、p><p>  表 2.5 Mininet常用命令如下表所列</p><p>  表 2.6 Mininet啟動時常用參數(shù)介紹如下表所列</p><p>  2.3.3 Mininet的結(jié)構(gòu)分析</p><p>  Mininet中將網(wǎng)絡(luò)元素分為鏈路和節(jié)點兩種類型,并且對于每一種設(shè)備都有相應(yīng)的標記網(wǎng)絡(luò)元素的各種屬性和操作。Node類表示一個基本的

80、虛擬網(wǎng)絡(luò)節(jié)點,是Mininet中所有的挽留過節(jié)點的父類,其中包含名稱,命名空間,接口,端口等公共屬性,實現(xiàn)上其實就是在網(wǎng)絡(luò)名字空間中的一個shell進程,可以通過各種管道進行通信,其子類包含了虛擬注解節(jié)點Host類,虛擬交換節(jié)點switch類和控制節(jié)點controller類,圖2.4畫出了Node類及其所有子類的集成關(guān)系,Host包括Host和CPULImitedHost兩個類,CPULimitedHost類用于控制主機的CPU使用率;

81、Switch在Node類的基礎(chǔ)上加入了數(shù)據(jù)通路、參數(shù)、監(jiān)聽端口等Openflow交換機所具備的基本屬性,且包括四個子類,用于支持多種Openflow交換機軟件,包含:</p><p>  a. UserSwitch類:用戶態(tài)的Openflow參考交換機,即ofdatapath;</p><p>  b. OVSLegacyKernelSwitch類:傳統(tǒng)的Openvswitch交換機,基于

82、</p><p>  ovs-openflowd;</p><p>  c. OVSKernelSwitch類:表示一臺基于opensvswitch交換機,基于ovs-vsctl</p><p><b>  進行操作。</b></p><p>  d. IVSSwitch類:表示一臺indigo交換機。</p>

83、;<p>  Controller在Node類的基礎(chǔ)上增加了IP地址,端口等用于連接控制器的參數(shù)屬性,并支持檢查控制器的狀態(tài),主要方法包括啟動停止一個控制器。Controller類包含三個子類用于支持多種openflow控制器軟件,包含:</p><p>  a. OVSController類:用于支持Mininet內(nèi)置的OVS控制器。</p><p>  b. NOX類:用

84、于支持Mininet內(nèi)置的NOX控制器。</p><p>  c. RemoteController類:表示一個在Mininet控制器外的控制器,比如</p><p>  Opendaylight,即用戶自己額外運行的控制器。</p><p>  圖 2.4 網(wǎng)絡(luò)節(jié)點示例</p><p>  與節(jié)點類相對應(yīng),Mininet中提供了鏈路類用于

85、連接各節(jié)點,類名稱為link。鏈路類描述鏈路相關(guān)的接口和連接,包括Intf類,Link類,TCIntf類,和TCLink</p><p><b>  類。</b></p><p>  a. Intf類:表示基本的網(wǎng)絡(luò)接口,比如h1-eth0表示host1上的eth0的接口。 </p><p>  屬性包括name,mac,ip等信息。構(gòu)造的時候

86、會傳入節(jié)點,端口等屬性。</p><p>  b. Link類:表示基本的一跳鏈路,最基本的鏈路在mininet中其實就是veth</p><p>  接口,屬性包含了鏈路兩端對應(yīng)的接口所對應(yīng)的實例,創(chuàng)建鏈路時需要在</p><p>  兩個節(jié)點上分別生產(chǎn)兩個端口,利用節(jié)點和端口,獲取對應(yīng)的兩個網(wǎng)絡(luò)接</p><p><b>  口

87、的名稱。</b></p><p>  c. TCIntf類:被TC自定義的接口,可以配置包括帶寬,延遲,丟包率,最</p><p><b>  大隊列長度等參數(shù)。</b></p><p>  d. TCLink類:表示已對對稱的TC接口連接到一起。</p><p>  2.4 Opendaylight的應(yīng)用&

88、lt;/p><p>  2.4.1 Opendaylight 概述</p><p>  Opendaylight是linux基金會的一個合作項目。目前,包括十二個項目,每一個項目都有自己的代碼庫,其中與openflow(南向接口協(xié)議)有聯(lián)系的包括:conroller,openflowjava和openflowplugin,目前controller僅支持openflow1.0,openflowp

89、lugin是一個單獨項目,在未來的發(fā)展過程中他的核心代碼部分將要集成到controller中,使得controller支持openflow1.3及以上版本。</p><p>  Opendaylight作為最近幾年迅速發(fā)展起來的項目,加入其中的廠商也逐漸增多,opendaylight將其分為白金會員,金牌會員,銀牌會員,包括思科,IBM,NEC,JUNIPER,DELL等等。 </p><p&

90、gt;  Opendaylight-controller使用Java編寫,運行在JVM環(huán)境下,從理論上來講可以運行在任何支持Java的平臺上。但是官方推薦的最佳運行環(huán)境為Linux(Ubuntu 12.04)& JVM 1.7+ 。Opendaylight提供了一個模塊化的的開放的SDN控制器,他提供北向的API(主要性應(yīng)用層提供服務(wù)),同時南向支持多種包括Openflow在內(nèi)的多種SDN協(xié)議,底層支持混合模式的交換機和經(jīng)典的O

91、penflow交換機。</p><p>  Opendaylight controller在設(shè)計的時候遵循了六個基本架構(gòu)原則:</p><p>  a. 運行時模塊化和擴展化(Runtime Modularity and Extensibility):支持在</p><p>  控制器運行時進行服務(wù)的安裝、刪除和更新。</p><p>  b

92、. 多協(xié)議的南向接口協(xié)議支持(Mulitiprotocol Southbound):南向支持多種協(xié)</p><p><b>  議。</b></p><p>  c. 服務(wù)抽形層(Service Abstraction Layer):南向多種協(xié)議對上提供統(tǒng)一的 </p><p><b>  北向服務(wù)接口,</b></

93、p><p>  d. 開放的的可擴展北向API(Open Extensible NorthBound API):提供可擴</p><p>  展的應(yīng)用API,通過REST或者函數(shù)調(diào)用的方式。</p><p>  e. 支持多租戶,切片(support for multitenancy/slicing):允許網(wǎng)絡(luò)在邏輯</p><p>  上(或物

94、理上)劃分成不同的切片或租戶,控制器的部分功能和模塊可</p><p>  以管理制定的切片??刂破鞲鶕?jù)所管理的分片來呈現(xiàn)不同的控制觀測面。</p><p>  f. 一致性聚合(Consistent Clustering):提供細粒度復(fù)制的聚合和確保網(wǎng)絡(luò)一 </p><p><b>  致性的橫向擴展。</b></p><

95、p>  Opendaylight 南向通過plugin的方式來支持多種協(xié)議,包括openflow 1.0,openflow 1.3,BGP-LS等,這些模塊被動態(tài)的掛載到服務(wù)抽象層,SAL為上層提供服務(wù),將來自上層的調(diào)用封裝為適合底層網(wǎng)絡(luò)設(shè)備的協(xié)議格式,控制器需要獲取底層設(shè)備功能,可達性,等方面的消息,這些信息被存放在拓撲管理器(Tpology Manager)中,其他的組件包括ARP handler、Host Tracker、D

96、evice Manager和Switch Manager 則為Topology生成拓撲數(shù)據(jù)。</p><p>  Opendaylight的opendaylightplugin和opendaylightjava項目的目標是支持openflow1.3及以上的協(xié)議,由于openflow協(xié)議設(shè)計的時候并沒有考慮向后的兼容性,openflow1.3 plugn和openflow1.0采用了完全不同的設(shè)計。集成到contr

97、oller的openflow1.0 plugin是由openflow plugin和openflowj-ava兩部分實現(xiàn)的。</p><p>  使用Opendaylight的DLUX獲取拓撲信息:</p><p>  2.4.1 Opendaylight 項目架構(gòu)</p><p>  Opendaylight項目在各大公司的參與和推動下,不僅蔥粉體現(xiàn)了SDN的魅力

98、,也體現(xiàn)了各大企業(yè)的防御戰(zhàn)術(shù),ODL架構(gòu)的控制器采用的是cisco和OnePK(如圖2.5所示)架構(gòu),對比OnePK架構(gòu),和Opendaylight系統(tǒng)平臺的架構(gòu)皆可以看到二者的相似點了。</p><p>  圖 2.5 cisco的OnePK框架</p><p>  cisco的OnePK采用多層次的實現(xiàn)方案,中間層是系統(tǒng)實現(xiàn)層,然后向下層提供網(wǎng)絡(luò)接口,向上層提供業(yè)務(wù)開放接口。通過思科操

99、作系統(tǒng)和硬件平臺進行深入的編程訪問實現(xiàn)了OnePK,用來輔助網(wǎng)絡(luò)系統(tǒng)應(yīng)對Openflow在網(wǎng)絡(luò)架構(gòu)和設(shè)備方面帶來的巨大沖擊。</p><p>  而相對的,Opendaylight系統(tǒng)平臺共有三個部分,如圖(2.6所示),北向接口及內(nèi)置的應(yīng)用程序和服務(wù)、中間核心的網(wǎng)絡(luò)和平臺服務(wù)部分,以及最下層的南向接口,這與OnePK在層次結(jié)構(gòu)上幾乎是相同的。</p><p>  圖 2.6 openda

100、ylight系統(tǒng)框架</p><p>  Opendaylight在南向接口方面實現(xiàn)了一個事實:交換機并不僅僅運行轉(zhuǎn)發(fā)面的軟件,同樣有協(xié)議在運行。盡管SDN的本質(zhì)是管理面和轉(zhuǎn)發(fā)面分離,但是協(xié)議控制面可以和管理面一起,也可以和控制面一起,具有非常大的的機動性,這也為SDN框架的擴展提供了更多的可能性。</p><p><b>  2.5 本章小結(jié)</b></p&g

101、t;<p>  本章主要對SDN技術(shù)涉及的相關(guān)知識進行了介紹,包括ONF組織提出的SDN網(wǎng)絡(luò)架構(gòu),主要包括基礎(chǔ)設(shè)施層,控制層,應(yīng)用層,其次將南向接口協(xié)議的典型代表Openflow 的相關(guān)技術(shù)要點進行了了分析,然后介紹了了Mininet—一款模擬底層拓撲的基于linux系統(tǒng)的軟件,它能夠模擬出支持openflow協(xié)議的底層設(shè)備,最后介紹了控制器Opendaylight的架構(gòu)。</p><p>  3

102、基于SDN網(wǎng)絡(luò)框架設(shè)計</p><p><b>  3.1 拓撲的設(shè)計</b></p><p>  3.1.1 通過Mininet命令行實現(xiàn)</p><p>  通過mininet命令行能夠?qū)崿F(xiàn)簡單的拓撲,在Mininet的命令行可以直接利用命令來創(chuàng)建拓撲。比如輸入sudo mn,就會創(chuàng)建默認的拓撲,包含一臺控制器,一天交換機,兩臺主機。如圖3

103、.1所示</p><p>  圖 3.1 Mininet 創(chuàng)建默認拓撲</p><p>  并且在sudo mn之后也可以加上相關(guān)參數(shù)來達到設(shè)置拓撲的目的,如表3.1所示:</p><p>  表3.1 mininet命令行創(chuàng)建拓撲的命令示例</p><p>  3.1.2 通過python腳本設(shè)計拓撲</p><p>

104、;  通過Mininet的命令行只能完成一些簡單的拓撲,如果需要稍微復(fù)雜的網(wǎng)絡(luò)結(jié)構(gòu),就需要通過Python腳本來實現(xiàn),其中在mininet中的--mininet/custom文件夾中專門存放拓撲文件,如圖3.2所示</p><p>  圖 3.2 拓撲文件夾</p><p>  要調(diào)用該文件夾中的test 1.py文件,需要在Mininet的命令行使用mn --topo=mytopo -

105、-custom test1.py 執(zhí)行后結(jié)果如圖3.3所示:</p><p>  圖 3.3 通過腳本執(zhí)行拓撲的結(jié)果</p><p>  創(chuàng)建python的過程如下:</p><p>  a. 使用vi命令進入指定文件夾,并創(chuàng)建文件。</p><p>  b. 編輯python腳本,其中腳本創(chuàng)建如下</p><p> 

106、?。?)import Topo 類用于派生Mytopo 類</p><p>  (2)topo 類中包含構(gòu)建網(wǎng)絡(luò)的函數(shù)</p><p> ?。?)addHost(“host name”) 添加主機</p><p>  (4)addSwitch(“sw name”) 添加交換機 (5)addLink(node,node,port,port) 添加鏈路 &

107、lt;/p><p> ?。?)在topos 中添加mytopo, 值為MyTopo() 類;</p><p>  c. 在啟動mininet時將參數(shù)配置為本文件即可。</p><p>  下面是test1.py的實例程序:</p><p>  from mininet.topo import Topo //表示引入Topo類中的Mininet

108、.Topo</p><p>  class MyTopo(Topo): //創(chuàng)建MyTopo類</p><p>  "Simple topology example."</p><p>  def __init__(self): //定義topo函數(shù)</p><p>  "creat

109、e custom topo."</p><p>  # Initialize topology</p><p>  Topo.__init__(self) //topo函數(shù)初始化</p><p>  # Add hosts and switches</p><p>  host_1=self.addHost('

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論