<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > 在VxWorks下實(shí)現NAT/NAPT的方法

在VxWorks下實(shí)現NAT/NAPT的方法

作者: 時(shí)間:2004-12-10 來(lái)源:網(wǎng)絡(luò ) 收藏
摘要:介紹NAT、NAPT的基本概念和工作原理;結合的網(wǎng)絡(luò )協(xié)議棧,描述一種利用操作系統提供的鉤子函數來(lái)開(kāi)發(fā)NAT和NAPT的。

關(guān)鍵詞:NAT NAPT 鉤子函數 網(wǎng)絡(luò )協(xié)議棧 截獲 轉換 校驗和

引言

近年來(lái),隨著(zhù)Internet的迅猛發(fā)展,連入Internet的主機數量成倍增長(cháng)。由于最初設計Internet的時(shí)候并沒(méi)有考慮到需要支持這么大的規模,因而Internet使用的Ipv4協(xié)議中IP地址的長(cháng)度選擇了32位,它可以使IP包的格式很好地對齊;但是,目前IP地址的短缺已經(jīng)成為Internet面臨的最大問(wèn)題之一。

為了解決IP地址短缺的問(wèn)題,人們提出了許多解決方案,nternet能夠支持到新一代IP協(xié)議Ipv6的出臺。在眾多的解決方案中,網(wǎng)絡(luò )地址轉換NAT(Network Address Translation)技術(shù)提供了一種完全將私有網(wǎng)和公共網(wǎng)隔離的,從而得到了廣泛的應用。

圖1 NAT工作原理示意圖

1 NAT技術(shù)

NAT技術(shù)的基本功能就是,用1個(gè)或幾個(gè)IP地址來(lái)1個(gè)私有網(wǎng)中的所有主機和公共網(wǎng)中主機的IP通信。NAT技術(shù)可為T(mén)CP、UDP以及ICMP數據包提供透明轉發(fā)。

1.1 NAT工作原理

NAT的基本工作原理是,當私有網(wǎng)主機和公共網(wǎng)主機通信的IP包經(jīng)過(guò)NAT網(wǎng)關(guān)時(shí),將IP包中的源IP或目的IP在私有IP和NAT的公共IP之間進(jìn)行轉換。

如圖1所示,NAT網(wǎng)關(guān)有2個(gè)網(wǎng)絡(luò )端口,其中公共網(wǎng)絡(luò )端口的IP地址是統一分配的公共IP,為202.204.65.2;私有網(wǎng)絡(luò )端口的IP地址是保留地址,為192.168.1.1。私有網(wǎng)中的主機192.168.1.2向公共網(wǎng)中的主機166.111.80.200發(fā)送了1個(gè)IP包(Des=166.111.80.200,Src=192.168.1.2)。當IP包經(jīng)過(guò)NAT網(wǎng)關(guān)時(shí),NAT會(huì )將IP包的源IP轉換為NAT的公共IP并轉發(fā)到公共網(wǎng),此時(shí)IP包(Des=166.111.80.200,Src=202.204.65.2)中已經(jīng)不含任何私有網(wǎng)IP的信息。由于IP包的源IP已經(jīng)被轉換成NAT的公共IP,響應的IP包(Des=202.204.65.2,Src=166.111.80.200)將被發(fā)送到NAT。這時(shí),NAT會(huì )將IP包的目的IP轉換成私有網(wǎng)中主機的IP,然后將IP包(Des=192.168.1.2,Src=166.111.80.200)轉發(fā)到私有網(wǎng)。對于通信雙方而言,這種地址的轉換過(guò)程是完全透明的。

1.2 NAPT技術(shù)

由于NAT是私有IP和NAT的公共IP之間的轉換,那么,私有網(wǎng)中同時(shí)與公共網(wǎng)進(jìn)行通信的主機數量就受到NAT的公共IP地址數量的限制。為了克服這種限制,NAT被進(jìn)一步擴展到在進(jìn)行IP地址轉換的同時(shí)進(jìn)行Port的轉換,這就是網(wǎng)絡(luò )地址端口轉換NAPT(Network Address Port Translation)技術(shù)。

NAPT與NAT的區別在于,NAPT不僅轉換IP包中的IP地址,還對IP包中TCP和UDP的Port進(jìn)行轉換。這使得多臺私有網(wǎng)主機利用1個(gè)NAT公共IP就可以同時(shí)和公共網(wǎng)進(jìn)行通信。

如圖2所示,私有網(wǎng)主機192.168.1.2要訪(fǎng)問(wèn)公共網(wǎng)中的Http服務(wù)器166.111.80.200。首先,要建立TCP連接,假設分配的TCP Port是1010,發(fā)送了1個(gè)IP包(Des=166.111.80.200:80,Src=192.168.1.2:1010),當IP包經(jīng)過(guò)NAT網(wǎng)關(guān)時(shí),NAT會(huì )將IP包的源IP轉換為NAT的公共IP,同時(shí)將源Port轉換為NAT動(dòng)態(tài)分配的1個(gè)Port。然后,轉發(fā)到公共網(wǎng),此時(shí)IP包(Des=166.111.80.200:80,Src=202.204.65.2:2010)已經(jīng)不含任何私有網(wǎng)IP和Port的信息。由于IP包的源IP和Port已經(jīng)被轉換成NAT的公共IP和Port,響應的IP包(Des=202.204.65.2:,Src=2010166.111.80.200:80)將被發(fā)送到NAT。這時(shí)NAT會(huì )將IP包的目的IP轉換成私有網(wǎng)主機的IP,同時(shí)將目的Port轉換為私有網(wǎng)主機的Port,然后將IP包(Des=192.168.1.2:1010,Src=166.111.80.200:80)轉發(fā)到私網(wǎng)。對于通信雙方而言,這種IP地址和Port的轉換是完全透明的。

2 的網(wǎng)絡(luò )協(xié)議棧

與VxWorks操作系統捆綁發(fā)行的標準網(wǎng)絡(luò )協(xié)議棧,是一個(gè)與BSD4.4兼容、功能齊全并針對嵌入式應用作了大量?jì)?yōu)化的TCP/IP協(xié)議棧。該網(wǎng)絡(luò )協(xié)議棧與VxWorks操作系統、開(kāi)發(fā)工具、設備管理工具以及上層協(xié)議和應用可以集成在一起,有完整的路由功能并可以根據需要進(jìn)行剪裁。VxWorks的網(wǎng)絡(luò )協(xié)議棧的分層結構如圖3所示。

VxWorks網(wǎng)絡(luò )協(xié)議棧傳輸數據使用的內存,是在系統啟動(dòng)進(jìn)行網(wǎng)絡(luò )協(xié)議初始化的時(shí)候就申請下來(lái)的,并使用系統提供的netBufLib建立內存字點(diǎn)池來(lái)管理這些內存空間。網(wǎng)絡(luò )協(xié)議棧傳輸數據所需的內存都是從這些內存節點(diǎn)池中申請,使用完畢后再釋放。

NetBufLib通過(guò)3種數據結構處理網(wǎng)絡(luò )協(xié)議棧傳輸的數據:mBlk、clBlk和Cluster。其中,Cluster保存的是實(shí)際的數據,mBlk和clBlk中保存的信息是用來(lái)管理Cluster中保存的數據的。為了滿(mǎn)足傳輸不同大小數據的需要,Cluster是一些大小不同的內存塊;缺省情況下,VxWorks網(wǎng)絡(luò )協(xié)議棧創(chuàng )建了大小從64~2048字節的6個(gè)不同的內存節點(diǎn)池。

由于mBlk中保存的只是指向數據的指針,因此,網(wǎng)絡(luò )協(xié)議棧不同層之間的數據傳輸可以避免數據拷貝。此外,對于分布在多個(gè)Cluster中的數據,可以通過(guò)mBlk把它們鏈在一起,并且只需要傳遞鏈首的mBlk就可以了。VxWorks網(wǎng)絡(luò )協(xié)議棧的“零拷貝”技術(shù)就是建立在這種機制的基礎之上的。圖4描述了2個(gè)提交給網(wǎng)絡(luò )協(xié)議棧TCP層的包的數據結構。

在mBlk結構中,有2個(gè)指向其它mBlk的指針:1個(gè)指向同一個(gè)包的下一個(gè)mBlk;另一個(gè)指向下一個(gè)包的鏈首的mBlk。ClBlk指向的就是實(shí)際存儲數據的Cluster。

3 向VxWorks網(wǎng)絡(luò )協(xié)議棧加入NAT

為了向VxWorks網(wǎng)絡(luò )協(xié)議棧中加入NAT,必須實(shí)現2個(gè)基本操作:IP包的截獲得IP包的處理。

3.1 VxWorks下IP包的截獲

VxWorks網(wǎng)絡(luò )協(xié)議棧在物理驅動(dòng)層和IP層上分別提供了兩類(lèi)鉤子函數:EtherHook和IpFilterHook。利用這兩類(lèi)鉤子函數,可以實(shí)現對IP包的截獲。

(1)EtherHook

EtherHook提供對以太幀的截獲功能。它包括2個(gè)鉤子函數:以太幀接收鉤子函數EtherInputHook和以太幀發(fā)送鉤子函數EtherOutPutHook。它們分別用函數EtherInputHookAdd和EtherOutputHookAdd安裝。安裝了這些鉤子函數后,每當有以太幀被接收到時(shí),函數EtherInputHook就會(huì )在該以太幀被提交給上層處理前被自動(dòng)調用;每當有以太幀被發(fā)送時(shí),函數EtherOutputHook會(huì )在該以太幀被發(fā)送前被自動(dòng)調用。通過(guò)截獲以太帖,可以達到截獲IP包的目的。

(2)IpFilterHook

IpFilterHook提供對IP包的截獲功能。它只對應1個(gè)鉤子函數,用函數ipFilterHookAdd就可以完成IpFilterHook的安裝。安裝了IpFilterHook后,每當有IP包被接收到時(shí),函數IpFilterHook就會(huì )被自動(dòng)調用,從而實(shí)現對IP包的截獲。

3.2 NAT過(guò)程中IP包的處理

利用鉤子函數完成IP包的截獲后,就可以根據需要對IP包進(jìn)行處理。首先,可以從IP包中剝離出IP頭,根據IP頭中的“協(xié)議”域可以判斷出是UDP包還是TCP包。然后,從IP包中剝離出UDP頭或TCP頭,利用IP頭和UDP頭或者TCP頭中的相關(guān)信息,就可以根據需要進(jìn)行IP地址和Port的轉換處理。

NAT一般采用1個(gè)映射表來(lái)實(shí)現IP地址和Port的轉換。對于截獲到的IP包,通過(guò)比較IP包的目的IP、目的Port、源IP、源Port和NAT映射表中的相應表現,對IP包的目的IP、目的Port、源IP、源Port進(jìn)行轉換。

典型的NAT映射表如圖5所示。

(1)處理由內到外的IP包

由內到外的IP包指的是私有網(wǎng)主機通過(guò)NAT發(fā)送到公共網(wǎng)主機的IP包。它的源IP是私有IP,目的IP是公共IP。

當截獲到1個(gè)由內到外的IP包時(shí),NAT首先以IP包的源IP和源Port作為Real Src IP和Real Src Port的匹配條件,在映射表中進(jìn)行搜索。如果找到1個(gè)對應的表項,就用表項的NAT IP和NAT Port替換IP包的源IP和源Port,而保持IP包的目的IP和目的Port不變。然后,重新計算TCP或UDP的校驗和,就可把IP包歸還給VxWorks網(wǎng)絡(luò )協(xié)議棧。

如果在映射表中沒(méi)有搜索到對應的表項,NAT就會(huì )向映射表中添加1個(gè)新的表現。該表項中的Real Src IP和Real Src Port用IP包的源IP和源Port來(lái)填充;NAT Port用NAT分配的1個(gè)空閑Port填充。然后,根據新增加的表項,按照上面相同的步驟完成對IP包的處理。后續相同的IP包也都用這個(gè)表項來(lái)處理。

(2)處理由外到內的IP包

由外到內的IP包指的是從公共網(wǎng)通過(guò)NAT發(fā)送到私有用的IP包。它的源IP是公共IP,目的IP是NAT的公共IP。

當截獲到1個(gè)由外到內的IP包時(shí),NAT就以IP包的目的IP和目的Port作為NAT IP和NAT Port的匹配條件,在映射表中進(jìn)行搜索。如果找到1個(gè)對應的表項,就用表項的Real Src IP和Real Src Port來(lái)替換IP包的目的IP和目的Port,而保持IP包的源IP和源Port不變。然后,重新計算TCP或UDP的校驗和,就可把IP包歸還給VxWorks網(wǎng)絡(luò )協(xié)議棧。

如果在映射表中沒(méi)有搜索到對應的表項,則對IP包不作任何處理,直接歸還給VxWorks網(wǎng)絡(luò )協(xié)議棧。

(3)NAT映射表的配置

作為NAT完成IP包中IP和Port轉換的依據,NAT映射表的管理關(guān)系到NAT的功能和性能。NAT映射表的配置可以分為2部分:靜態(tài)配置部分和動(dòng)態(tài)配置部分。

靜態(tài)配置部分主要用于NAT IP、NAT Port和私有IP、私有Port的映射關(guān)系可以預見(jiàn)的應用,例如UDP通信和TCP Server運行在私網(wǎng)中某個(gè)主機等情況。NAT映射表靜態(tài)配置部分可以在NAT運行前根據規劃直接完成配置。

動(dòng)態(tài)配置部分主要用于NAT IP、NAT Port和私有IP、私有Port的映射關(guān)系不可預見(jiàn)的應用,例如在私有網(wǎng)中某個(gè)主機上運行TCP Client來(lái)與公共網(wǎng)中某個(gè)主機上的TCP Server建立連接進(jìn)行通信。因這種情況下,私有網(wǎng)主機使用的Port是動(dòng)態(tài)分配的。為了實(shí)現需要NAT IP、NAT Port和私有IP、私有Port的轉換,必須動(dòng)態(tài)配置NAT映射表。相對于靜態(tài)配置部分而言,動(dòng)態(tài)配置部分的數據結構、數據組織和搜索算法的設計和實(shí)現的難度要大得多,關(guān)鍵是要實(shí)現一個(gè)高效的搜索算法。

tcp/ip相關(guān)文章:tcp/ip是什么




關(guān)鍵詞: 方法 NAT/NAPT 實(shí)現 VxWorks

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>