韓江雪++李昕
摘要:衛(wèi)星通信網(wǎng)絡(luò)早在20世紀(jì)初期就已經(jīng)被提出,地面網(wǎng)絡(luò)通信系統(tǒng)無法滿足日益增長的通信業(yè)務(wù)發(fā)展需求,商業(yè)和軍事領(lǐng)域也直接或間接地推動(dòng)了衛(wèi)星通信系統(tǒng)的發(fā)展。隨著衛(wèi)星通信網(wǎng)絡(luò)越來越復(fù)雜,衛(wèi)星組網(wǎng)向多層化發(fā)展,而典型的地面網(wǎng)絡(luò)路由技術(shù)由無法應(yīng)用于衛(wèi)星網(wǎng)絡(luò),因此,衛(wèi)星通信系統(tǒng)中如何進(jìn)行有效的路由選擇也逐漸成為新的焦點(diǎn)問題。而由于衛(wèi)星網(wǎng)絡(luò)路由技術(shù)應(yīng)用環(huán)境的特殊性,研究人員無法基于真實(shí)網(wǎng)絡(luò)環(huán)境進(jìn)行研究,只能通過仿真工具進(jìn)行仿真實(shí)驗(yàn),NS2是指Network Simulator version 2,NS(Network Simulator)是開源的軟件模擬平臺(tái),研究人員使用它對(duì)網(wǎng)絡(luò)技術(shù)進(jìn)行開發(fā)研究,NS2已經(jīng)包含了衛(wèi)星節(jié)點(diǎn)、衛(wèi)星鏈路等模塊,但是這些模塊較為簡單,只能模擬單層衛(wèi)星網(wǎng)絡(luò)。因此,本文提出了在NS2中模擬多層衛(wèi)星網(wǎng)絡(luò),實(shí)現(xiàn)層間通信,研發(fā)多層衛(wèi)星網(wǎng)絡(luò)路由協(xié)議的方法。
關(guān)鍵詞:計(jì)算機(jī)仿真;衛(wèi)星網(wǎng)絡(luò);路由協(xié)議;NS2
中圖分類號(hào):TP319
文獻(xiàn)標(biāo)識(shí)碼:A
DOI:10.3969/j.issn.1003-6970.2016.02.016
引言
衛(wèi)星網(wǎng)絡(luò)通信范圍覆蓋全球,可以保證較高速率的傳輸速度,支持大規(guī)模可擴(kuò)展的網(wǎng)絡(luò)結(jié)構(gòu),當(dāng)前,衛(wèi)星網(wǎng)絡(luò)星座主要有單層衛(wèi)星星座和多層衛(wèi)星星座兩種,主要包含低軌道衛(wèi)星(IEO),中軌道衛(wèi)星(MEO)或者地球同步衛(wèi)星(GEO)三種軌道類型的衛(wèi)星,目前,世界上各個(gè)國家都已經(jīng)建立起了較為完善的衛(wèi)星通信網(wǎng)絡(luò)系統(tǒng)。而未來的衛(wèi)星通信系統(tǒng)勢必要為更多的用戶提供更快速更加高效可靠的通信服務(wù)。因此,結(jié)合多軌道、多層次的衛(wèi)星構(gòu)建更廣泛更健壯的立體式多層衛(wèi)星網(wǎng)絡(luò)通信系統(tǒng)已經(jīng)成為衛(wèi)星網(wǎng)絡(luò)的發(fā)展趨勢,隨著空間網(wǎng)絡(luò)越來越復(fù)雜化,多層衛(wèi)星通信網(wǎng)絡(luò)中如何實(shí)現(xiàn)快速有效的路由問題也日益成為新的研究焦點(diǎn)。而由于衛(wèi)星網(wǎng)絡(luò)的特殊性,普通研究人員沒有條件在實(shí)際網(wǎng)絡(luò)中進(jìn)行研究,只能通過仿真平臺(tái)進(jìn)行,因此,本文將描述如何在NS2中模擬多層衛(wèi)星網(wǎng)絡(luò)拓?fù)洌抡鎸娱g衛(wèi)星鏈路,實(shí)現(xiàn)星間通信,研發(fā)多層衛(wèi)星網(wǎng)絡(luò)中的路由協(xié)議。
1 多層衛(wèi)星網(wǎng)絡(luò)
多層衛(wèi)星網(wǎng)絡(luò)是指結(jié)合低軌道衛(wèi)星,中軌道衛(wèi)星或者地球同步衛(wèi)星,使用層間衛(wèi)星鏈路連接不同軌道的衛(wèi)星群體,結(jié)合不同軌道衛(wèi)星的優(yōu)勢,建立起立體式、多層次、交叉覆蓋的衛(wèi)星網(wǎng)絡(luò),多層衛(wèi)星通信網(wǎng)絡(luò)的拓?fù)浣Y(jié)構(gòu)如下圖所示:
相對(duì)于單層衛(wèi)星構(gòu)成的空間網(wǎng)絡(luò),多層衛(wèi)星通信網(wǎng)絡(luò)具有更高的可擴(kuò)展性、靈活性以及強(qiáng)的抗毀性。要使用衛(wèi)星組網(wǎng),必須首先解決網(wǎng)絡(luò)中如何快速有效進(jìn)行路由的問題,多層衛(wèi)星網(wǎng)絡(luò)的路由算法大多采用集中式路由方式,高層衛(wèi)星為集中控制群體,低層衛(wèi)星為接入衛(wèi)星,通信過程中由高層衛(wèi)星為低層計(jì)算最優(yōu)路徑,數(shù)據(jù)在低層衛(wèi)星中進(jìn)行轉(zhuǎn)發(fā)。
2 NS2仿真平臺(tái)
NS2仿真平臺(tái)實(shí)際上模擬了一個(gè)時(shí)間調(diào)度引擎,調(diào)度引擎的核心對(duì)象是調(diào)度器類,負(fù)責(zé)進(jìn)行時(shí)間推進(jìn)并對(duì)在時(shí)間軸上的各個(gè)事件隊(duì)列進(jìn)行調(diào)度,調(diào)度的過程中可能會(huì)在新的時(shí)刻觸發(fā)新的事件,那么這些事件就會(huì)被加入對(duì)應(yīng)時(shí)間點(diǎn)上的事件隊(duì)列中,等待調(diào)度引擎進(jìn)行調(diào)度。調(diào)度器類采用先進(jìn)先出的數(shù)據(jù)結(jié)構(gòu)逐個(gè)調(diào)度事件,直到時(shí)間推進(jìn)到仿真結(jié)束時(shí)刻,模擬過程中止。
NS2使用C++和Otcl語言進(jìn)行開發(fā),Otcl語言負(fù)責(zé)編寫仿真腳本,制定仿真計(jì)劃,調(diào)用NS2中封裝好的各個(gè)功能模塊,C++語言對(duì)tcl腳本解釋執(zhí)行。
NS2仿真平臺(tái)已經(jīng)封裝了許多功能模塊,最基本的是節(jié)點(diǎn)、鏈路、數(shù)據(jù)包格式等等。其中也包括了衛(wèi)星網(wǎng)絡(luò)仿真模塊,但是實(shí)現(xiàn)的衛(wèi)星網(wǎng)絡(luò)功能較為簡單并且與真實(shí)場景差異較大,仿真實(shí)驗(yàn)時(shí)需要在這部分功能的基礎(chǔ)上進(jìn)行二次開發(fā)。
2.1 衛(wèi)星網(wǎng)絡(luò)模塊
NS2中衛(wèi)星網(wǎng)絡(luò)仿真模塊的核心代碼在ns-2.35目錄下的satellite文件夾中,主要包括satnode類,sathandoff類,satroute類,satlink類等源文件分別用來模擬衛(wèi)星節(jié)點(diǎn)、衛(wèi)星鏈路切換、衛(wèi)星路由、衛(wèi)星鏈路等。
2.1.1 sathandoff模塊
由于衛(wèi)星的移動(dòng)性,不同軌道間的衛(wèi)星或者是地面站與衛(wèi)星間為了保證能夠正常通信需要經(jīng)常進(jìn)行鏈路切換(找到一顆位置上更加合適的衛(wèi)星連接上),sathandoff就是負(fù)責(zé)這部分的工作,其中包括termhandoff以及sathandoff兩個(gè)主要的函數(shù)分別包含了地面站和衛(wèi)星的切換機(jī)制。每顆衛(wèi)星都包含一個(gè)sathandoff的實(shí)例,切換是由鏈路檢測切換時(shí)間來控制的,在tcl腳本中配置好鏈路切換檢測的周期,每顆衛(wèi)星或地面站就會(huì)周期性地調(diào)用sathandoff或者termhandoff函數(shù)檢測并切換鏈路(需要切換時(shí))。
2.1.2 satroute模塊
satroute類模擬了衛(wèi)星路由層的功能,其中Recv和ForwardPacket兩個(gè)函數(shù)實(shí)現(xiàn)了收、發(fā)數(shù)據(jù)包的功能。NS2白帶了一個(gè)集中式的路由代理satRouteLogic類,默認(rèn)情況下,當(dāng)衛(wèi)星需要轉(zhuǎn)發(fā)數(shù)據(jù)包時(shí)就使用這個(gè)路由代理類計(jì)算全網(wǎng)最短路徑路由表并依照路由表轉(zhuǎn)發(fā)數(shù)據(jù),最短路徑可以配置成使用跳數(shù)或鏈路時(shí)延兩種計(jì)算方式。使用路由代理類相當(dāng)于是默認(rèn)每顆衛(wèi)星在每一時(shí)刻都知道全網(wǎng)實(shí)時(shí)拓?fù)?,這顯然是不切實(shí)際的,因此實(shí)際仿真時(shí)不應(yīng)使用這個(gè)路由代理。
2.1.3 satlink模塊
satlink類負(fù)責(zé)模擬星間鏈路,包括星地鏈路、同層衛(wèi)星軌道內(nèi)鏈路、同層衛(wèi)星軌道間鏈路。
3 多層衛(wèi)星網(wǎng)絡(luò)路由協(xié)議在NS2中的實(shí)現(xiàn)方案
NS2仿真平臺(tái)中已經(jīng)實(shí)現(xiàn)了部分衛(wèi)星網(wǎng)絡(luò)仿真模塊,擁有極地衛(wèi)星節(jié)點(diǎn)和地球同步衛(wèi)星節(jié)點(diǎn),但是星間鏈路只包括同層衛(wèi)星之間的鏈路,沒有層間鏈路的定義與實(shí)現(xiàn)。并且模塊中實(shí)現(xiàn)的路由功能使用的是集中式的路由代理satRouteLogic類,每顆衛(wèi)星轉(zhuǎn)發(fā)數(shù)據(jù)時(shí)由路由代理類實(shí)時(shí)根據(jù)全網(wǎng)拓?fù)溆?jì)算網(wǎng)絡(luò)最短路徑,這也與實(shí)際情況不符,因此,需要將自己的路由協(xié)議方案,下面,將從層間鏈路、鏈路切換、星間通信、路由模塊等方面介紹如何在NS2中搭建多層衛(wèi)星網(wǎng)絡(luò)以及仿真自己的路由協(xié)議。
3.1 層間鏈路及鏈路切換
NS2中satellite文件夾下的satlink.cc以及satlink.h文件實(shí)現(xiàn)了衛(wèi)星鏈路模塊,為了實(shí)現(xiàn)層間鏈路,首先在satlink.h中加入層間鏈路宏定義:
#defrne LINK ISL INTERLAYER 9
接著,在satlink.cc中定義在tcl語法中對(duì)層間鏈路的標(biāo)識(shí):
if(strcmp( argv[2], “geo”)==0){
type_=LrNK_GSL_GEO;
return TCL_OK:
}……
else if( strcmp( argv[2],“interlayer”)==0){
type_= LINK ISL_INTERLAYER;
retum TCL OK;
}
這樣就可以在tcl腳本中使用interlayer指令將兩顆不同層的衛(wèi)星進(jìn)行連接,如下代碼所示:
$ns add-isl interlayer $n(0)$n(1)$opt(bw_isl)$opt(ifq) $opt(qlim)
但是,這樣的連接是沒有實(shí)際意義的,因?yàn)閷娱g衛(wèi)星節(jié)點(diǎn)的運(yùn)動(dòng)軌跡不同,兩顆衛(wèi)星由于空間位置、傾角的原因不可能永久連接,因此,需要實(shí)現(xiàn)層間鏈路的鏈路切換功能。
鏈路切換功能是satellite文件夾下的sathandoff類,類中的handoff函數(shù)實(shí)現(xiàn)了軌道間鏈路,反向縫鏈路以及星地鏈路的切換功能。這里將層間鏈路的切換功能加入handoff函數(shù),層間鏈路切換的核心代碼如下:
for(slhp=(SatLinkHead*)local->linklisthead().lh_first;slhp;
slhp=(SatLinkHead*) slhp->nextlinkhead()){
peer_meo=get_peer(slhp);
peer_slhp_meo=get_peer_linkhead(slhp);
dist_to_peer_meo=SatGeometry::distance(peer_coord_meo,local_coord_);
int layerchanges=FALSE;
for(inti=MEO->minld;i <=MEO->count;i++)
{
double dist_to_Meo_next;
disttoMeonext=SatGeometry::distance(Meopos->coord(),local_coord_);
if(disttoMeonext peer_nextslhp_meo=getMeopeer_nextlinkhead(peer_next_meo); tx_channeI meo=slhp->phy_tx()->channel(); rx_channel_meo=slhp->phy_rx()->channel(); } } } 層間鏈路切換由低層衛(wèi)星觸發(fā),根據(jù)星間距離、傾角選擇一顆合適的高層衛(wèi)星進(jìn)行鏈路切換。 3.2 星間通信 主干衛(wèi)星為了為低層衛(wèi)星計(jì)算路由表,需要定期收集低層衛(wèi)星的鏈路狀態(tài),這就涉及到星間通信,但是在NS2中并沒有相應(yīng)的模塊實(shí)現(xiàn),為此,可以將低層衛(wèi)星定期上傳鏈路狀態(tài)的功能集成到衛(wèi)星路由模塊。衛(wèi)星路由模塊由satelite文件夾下的satroute類實(shí)現(xiàn)。首先在satroute類中創(chuàng)建定時(shí)器,負(fù)責(zé)周期性上傳鏈路狀態(tài)報(bào)告,在定時(shí)器觸發(fā)的函數(shù)中通過Pakcet類構(gòu)造鏈路狀態(tài)數(shù)據(jù)包并上傳給主干衛(wèi)星。核心代碼如下: NsObject*link_entry_; Packet*p=allocpkt(); hdr_ip *iph= hdr_ip::access(p); iph->saddr()=node()->address(); iph->daddr()=GeoAd; hdrc->la st_hop_=myaddr_;//for tracing purposes link_entry_=slhpGeo; link_entry_->recv(p,(Handler*)0); 3.3 路由模塊 satroute類實(shí)現(xiàn)了衛(wèi)星路由模塊,其中的Recv和ForwardPacket函數(shù)分別描述了衛(wèi)星節(jié)點(diǎn)的發(fā)送和接收數(shù)據(jù)包的功能。ForwardPacket函數(shù)調(diào)用了SatRouteLogic類實(shí)時(shí)計(jì)算路由表確定下一跳,在實(shí)際開發(fā)路由協(xié)議的時(shí),需要屏蔽SatRouteLogic類,調(diào)用自己生成的路由表進(jìn)行數(shù)據(jù)轉(zhuǎn)發(fā)。 首先,在satroute.h頭文件中定義路由表結(jié)構(gòu)體: struct slot_entry{ int next_hop; NsObject* entry; }; 低層衛(wèi)星的路由表由主干節(jié)點(diǎn)定期收集鏈路狀態(tài)報(bào)告并匯總后計(jì)算得出,主干節(jié)點(diǎn)計(jì)算完成后通過星間通信下發(fā)給低層衛(wèi)星,低層衛(wèi)星接收到路由表后更新slot_entry結(jié)構(gòu)體。 實(shí)際轉(zhuǎn)發(fā)數(shù)據(jù)包時(shí),只需在ForwardPacket函數(shù)中訪問slot_entry結(jié)構(gòu)體,找到下一跳節(jié)點(diǎn)并轉(zhuǎn)發(fā)數(shù)據(jù)即可完成路由工作。 4 結(jié)論 本文給出了如何在NS2仿真平臺(tái)中模擬多層衛(wèi)星網(wǎng)絡(luò),實(shí)現(xiàn)層間鏈路、鏈路切換、星間通信,仿真路由協(xié)議的方法,研究人員只需要按照文中介紹的內(nèi)容進(jìn)行開發(fā),即可實(shí)現(xiàn)多層衛(wèi)星網(wǎng)絡(luò)路由協(xié)議的仿真測試。