99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于VxWorks操作系統(tǒng)的網(wǎng)絡(luò)協(xié)議棧實現(xiàn)NAT/NAPT技術(shù)應(yīng)用

電子設(shè)計 ? 來源:單片機與嵌入式系統(tǒng)應(yīng)用 ? 作者:劉燕華,林立志 ? 2020-09-10 17:29 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

引言

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

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

1 NAT技術(shù)

NAT技術(shù)的基本功能就是,用1個或幾個IP地址來實現(xiàn)1個私有網(wǎng)中的所有主機和公共網(wǎng)中主機的IP通信。NAT技術(shù)可為TCP、UDP以及ICMP數(shù)據(jù)包提供透明轉(zhuǎn)發(fā)。

1.1 NAT工作原理

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

基于VxWorks操作系統(tǒng)的網(wǎng)絡(luò)協(xié)議棧實現(xiàn)NAT/NAPT技術(shù)應(yīng)用

圖1 NAT工作原理示意圖

如圖1所示,NAT網(wǎng)關(guān)有2個網(wǎng)絡(luò)端口,其中公共網(wǎng)絡(luò)端口的IP地址是統(tǒng)一分配的公共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個IP包(Des=166.111.80.200,Src=192.168.1.2)。當(dāng)IP包經(jīng)過NAT網(wǎng)關(guān)時,NAT會將IP包的源IP轉(zhuǎn)換為NAT的公共 IP并轉(zhuǎn)發(fā)到公共網(wǎng),此時IP包(Des=166.111.80.200,Src=202.204.65.2)中已經(jīng)不含任何私有網(wǎng)IP的信息。由于IP 包的源IP已經(jīng)被轉(zhuǎn)換成NAT的公共IP,響應(yīng)的IP包(Des=202.204.65.2,Src=166.111.80.200)將被發(fā)送到NAT。這時,NAT會將IP包的目的IP轉(zhuǎn)換成私有網(wǎng)中主機的IP,然后將IP包(Des=192.168.1.2,Src=166.111.80.200)轉(zhuǎn)發(fā)到私有網(wǎng)。對于通信雙方而言,這種地址的轉(zhuǎn)換過程是完全透明的。

1.2 NAPT技術(shù)

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

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

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

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

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

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

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

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

在mBlk結(jié)構(gòu)中,有2個指向其它mBlk的指針:1個指向同一個包的下一個mBlk;另一個指向下一個包的鏈?zhǔn)椎膍Blk。ClBlk指向的就是實際存儲數(shù)據(jù)的Cluster。

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

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

3.1 VxWorks下IP包的截獲

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

(1)EtherHook

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

(2)IpFilterHook

IpFilterHook提供對IP包的截獲功能。它只對應(yīng)1個鉤子函數(shù),用函數(shù)ipFilterHookAdd就可以完成 IpFilterHook的安裝。安裝了IpFilterHook后,每當(dāng)有IP包被接收到時,函數(shù)IpFilterHook就會被自動調(diào)用,從而實現(xiàn)對 IP包的截獲。

3.2 NAT過程中IP包的處理

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

NAT一般采用1個映射表來實現(xiàn)IP地址和Port的轉(zhuǎn)換。對于截獲到的IP包,通過比較IP包的目的IP、目的Port、源IP、源Port和NAT映射表中的相應(yīng)表現(xiàn),對IP包的目的IP、目的Port、源IP、源Port進行轉(zhuǎn)換。

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

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

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

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

如果在映射表中沒有搜索到對應(yīng)的表項,NAT就會向映射表中添加1個新的表現(xiàn)。該表項中的Real Src IP和Real Src Port用IP包的源IP和源Port來填充;NAT Port用NAT分配的1個空閑Port填充。然后,根據(jù)新增加的表項,按照上面相同的步驟完成對IP包的處理。后續(xù)相同的IP包也都用這個表項來處理。

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

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

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

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

(3)NAT映射表的配置

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

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

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

責(zé)任編輯:gt

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • IP
    IP
    +關(guān)注

    關(guān)注

    5

    文章

    1805

    瀏覽量

    152625
  • 服務(wù)器
    +關(guān)注

    關(guān)注

    13

    文章

    9796

    瀏覽量

    88016
  • 操作系統(tǒng)
    +關(guān)注

    關(guān)注

    37

    文章

    7152

    瀏覽量

    125632
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    VxWorks操作系統(tǒng)使用指南

    1. VxWorks操作系統(tǒng)概述1.1.VxWorks 操作系統(tǒng)簡介1.2.VxWorks操作系統(tǒng)
    發(fā)表于 07-20 13:10

    VxWorks嵌入式實時操作系統(tǒng)的采樣數(shù)據(jù)怎么發(fā)送?

    隨著科學(xué)技術(shù)的不斷發(fā)展,人們已經(jīng)無法滿足傳統(tǒng)的網(wǎng)絡(luò)通信方式,對于一種高性能的網(wǎng)絡(luò)通信的呼聲愈來愈高。VxWorks 是美國 Wind River SySTem 公司在1983年推出的一
    發(fā)表于 08-16 06:20

    如何向VxWorks網(wǎng)絡(luò)協(xié)議加入NAT?

    NAT的工作原理是什么如何向VxWorks網(wǎng)絡(luò)協(xié)議加入NAT?在
    發(fā)表于 04-28 06:11

    如何在VxWorks實現(xiàn)NAT/NAPT的方法

    如何在VxWorks實現(xiàn)NAT/NAPT的方法
    發(fā)表于 03-29 12:25 ?19次下載

    實時操作系統(tǒng)VxWorks下的并口通信技術(shù)

    實時操作系統(tǒng)VxWorks下的并口通信技術(shù)
    發(fā)表于 03-29 12:26 ?11次下載

    實時操作系統(tǒng)VxWorks下PCI總線配置技術(shù)

    實時操作系統(tǒng)VxWorks下PCI總線配置技術(shù)
    發(fā)表于 03-29 12:26 ?19次下載

    基于網(wǎng)絡(luò)處理器的VxWorks高層協(xié)議開發(fā)

    基于網(wǎng)絡(luò)處理器的VxWorks高層協(xié)議開發(fā)
    發(fā)表于 03-29 12:27 ?21次下載

    基于VxWorks系統(tǒng)的簡單網(wǎng)絡(luò)管理協(xié)議實現(xiàn)

    基于VxWorks系統(tǒng)的簡單網(wǎng)絡(luò)管理協(xié)議實現(xiàn)
    發(fā)表于 03-29 12:28 ?21次下載

    嵌入式VxWorks網(wǎng)絡(luò)協(xié)議的Mutiplexer接口及其使用方法

    嵌入式系統(tǒng)網(wǎng)絡(luò)協(xié)議的靈活性在應(yīng)用上是一個重要指標(biāo)。介紹嵌入式實時操作系統(tǒng)VxWorks
    發(fā)表于 04-09 10:00 ?10次下載

    VxWorks實現(xiàn)NAT NAPT的方法

    介紹NAT、NAPT的基本概念和工作原理;結(jié)合VxWorks網(wǎng)絡(luò)協(xié)議,描述一種利用
    發(fā)表于 05-15 14:35 ?12次下載

    VxWorks實現(xiàn)NAT NAPT的方法

    為了解決IP地址短缺的問題,人們提出了許多解決方案, 以使Internet能夠支撐到新一代IP協(xié)議IPv6的出臺。在眾多的解決方案中, 網(wǎng)絡(luò)地址轉(zhuǎn)換NAT (Network Address Translation)
    發(fā)表于 11-06 14:35 ?17次下載

    VxWorks操作系統(tǒng)指南

    1.VxWorks操作系統(tǒng)概述 4 1.1.VxWorks 操作系統(tǒng)簡介 4 1.2.VxWorks操作
    發(fā)表于 05-27 16:45 ?73次下載

    關(guān)于實時操作系統(tǒng)VxWorks下的并口通信技術(shù)

    關(guān)于實時操作系統(tǒng)VxWorks下的并口通信技術(shù)
    發(fā)表于 08-31 15:21 ?4次下載
    關(guān)于實時<b class='flag-5'>操作系統(tǒng)</b><b class='flag-5'>VxWorks</b>下的并口通信<b class='flag-5'>技術(shù)</b>

    基于VxWorks操作系統(tǒng)下光纖通道通信軟件的實現(xiàn)

    基于VxWorks操作系統(tǒng)下光纖通道通信軟件的實現(xiàn)
    發(fā)表于 08-31 17:08 ?4次下載
    基于<b class='flag-5'>VxWorks</b><b class='flag-5'>操作系統(tǒng)</b>下光纖通道通信軟件的<b class='flag-5'>實現(xiàn)</b>

    Linux網(wǎng)絡(luò)協(xié)議實現(xiàn)

    網(wǎng)絡(luò)協(xié)議操作系統(tǒng)核心的一個重要組成部分,負責(zé)管理網(wǎng)絡(luò)通信中的數(shù)據(jù)包處理。在 Linux 操作系統(tǒng)
    的頭像 發(fā)表于 09-10 09:51 ?712次閱讀
    Linux<b class='flag-5'>網(wǎng)絡(luò)</b><b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b>的<b class='flag-5'>實現(xiàn)</b>