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

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

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

一文讀懂p2p實(shí)現(xiàn)原理和NAT的類型

C語言專家集中營 ? 來源:feiyan ? 2018-12-09 10:50 ? 次閱讀

p2p實(shí)現(xiàn)原理

什么是打洞,為什么要打洞

由于Internet的快速發(fā)展 IPV4地址不夠用,不能每個(gè)主機(jī)分到一個(gè)公網(wǎng)IP 所以使用NAT地址轉(zhuǎn)換。

下面是我在網(wǎng)上找到的一副圖

一文讀懂p2p實(shí)現(xiàn)原理和NAT的類型

一般來說都是由私網(wǎng)內(nèi)主機(jī)(例如上圖中“電腦A-01”)主動(dòng)發(fā)起連接,數(shù)據(jù)包經(jīng)過NAT地址轉(zhuǎn)換后送給公網(wǎng)上的服務(wù)器(例如上圖中的“Server”),連接建立以后可雙向傳送數(shù)據(jù),NAT設(shè)備允許私網(wǎng)內(nèi)主機(jī)主動(dòng)向公網(wǎng)內(nèi)主機(jī)發(fā)送數(shù)據(jù),但卻禁止反方向的主動(dòng)傳遞,但在一些特殊的場合需要不同私網(wǎng)內(nèi)的主機(jī)進(jìn)行互聯(lián)(例如P2P軟件、網(wǎng)絡(luò)會(huì)議、視頻傳輸?shù)龋琓CP穿越NAT的問題必須解決。

下面是NAT的幾種類型

NAT設(shè)備的類型對于TCP穿越NAT,有著十分重要的影響,根據(jù)端口映射方式,NAT可分為如下4類,前3種NAT類型可統(tǒng)稱為cone類型。(1)全克隆( Full Clone) : NAT把所有來自相同內(nèi)部IP地址和端口的請求映射到相同的外部IP地址和端口。任何一個(gè)外部主機(jī)均可通過該映射發(fā)送IP包到該內(nèi)部主機(jī)。(2)限制性克隆(Restricted Clone) : NAT把所有來自相同內(nèi)部IP地址和端口的請求映射到相同的外部IP地址和端口。但是,只有當(dāng)內(nèi)部主機(jī)先給IP地址為X的外部主機(jī)發(fā)送IP包,該外部主機(jī)才能向該內(nèi)部主機(jī)發(fā)送IP包。(3)端口限制性克隆( Port Restricted Clone) :端口限制性克隆與限制性克隆類似,只是多了端口號的限制,即只有內(nèi)部主機(jī)先向IP地址為X,端口號為P的外部主機(jī)發(fā)送1個(gè)IP包,該外部主機(jī)才能夠把源端口號為P的IP包發(fā)送給該內(nèi)部主機(jī)。(4)對稱式NAT ( Symmetric NAT) :這種類型的NAT與上述3種類型的不同,在于當(dāng)同一內(nèi)部主機(jī)使用相同的端口與不同地址的外部主機(jī)進(jìn)行通信時(shí), NAT對該內(nèi)部主機(jī)的映射會(huì)有所不同。對稱式NAT不保證所有會(huì)話中的私有地址和公開IP之間綁定的一致性。相反,它為每個(gè)新的會(huì)話分配一個(gè)新的端口號。

先假設(shè):有一個(gè)服務(wù)器S在公網(wǎng)上有一個(gè)IP,兩個(gè)私網(wǎng)分別由NAT-A和NAT-B連接到公網(wǎng),NAT-A后面有一臺(tái)客戶端A,NAT-B后面有一臺(tái)客戶端B,現(xiàn)在,我們需要借助S將A和B建立直接的TCP連接,即由B向A打一個(gè)洞,讓A可以沿這個(gè)洞直接連接到B主機(jī),就好像NAT-B不存在一樣。

實(shí)現(xiàn)過程如下:1、 S啟動(dòng)兩個(gè)網(wǎng)絡(luò)偵聽,一個(gè)叫【主連接】偵聽,一個(gè)叫【協(xié)助打洞】的偵聽。2、 A和B分別與S的【主連接】保持聯(lián)系。3、 當(dāng)A需要和B建立直接的TCP連接時(shí),首先連接S的【協(xié)助打洞】端口,并發(fā)送協(xié)助連接申請。同時(shí)在該端口號上啟動(dòng)偵聽。注意由于要在相同的網(wǎng)絡(luò)終端上綁定到不同的套接字上,所以必須為這些套接字設(shè)置 SO_REUSEADDR 屬性(即允許重用),否則偵聽會(huì)失敗。4、 S的【協(xié)助打洞】連接收到A的申請后通過【主連接】通知B,并將A經(jīng)過NAT-A轉(zhuǎn)換后的公網(wǎng)IP地址和端口等信息告訴B。5、 B收到S的連接通知后首先與S的【協(xié)助打洞】端口連接,隨便發(fā)送一些數(shù)據(jù)后立即斷開,這樣做的目的是讓S能知道B經(jīng)過NAT-B轉(zhuǎn)換后的公網(wǎng)IP和端口號。6、 B嘗試與A的經(jīng)過NAT-A轉(zhuǎn)換后的公網(wǎng)IP地址和端口進(jìn)行connect,根據(jù)不同的路由器會(huì)有不同的結(jié)果,有些路由器在這個(gè)操作就能建立連接,大多數(shù)路由器對于不請自到的SYN請求包直接丟棄而導(dǎo)致connect失敗,但NAT-A會(huì)紀(jì)錄此次連接的源地址和端口號,為接下來真正的連接做好了準(zhǔn)備,這就是所謂的打洞,即B向A打了一個(gè)洞,下次A就能直接連接到B剛才使用的端口號了。7、 客戶端B打洞的同時(shí)在相同的端口上啟動(dòng)偵聽。B在一切準(zhǔn)備就緒以后通過與S的【主連接】回復(fù)消息“我已經(jīng)準(zhǔn)備好”,S在收到以后將B經(jīng)過NAT-B轉(zhuǎn)換后的公網(wǎng)IP和端口號告訴給A。8、 A收到S回復(fù)的B的公網(wǎng)IP和端口號等信息以后,開始連接到B公網(wǎng)IP和端口號,由于在步驟6中B曾經(jīng)嘗試連接過A的公網(wǎng)IP地址和端口,NAT-A紀(jì)錄了此次連接的信息,所以當(dāng)A主動(dòng)連接B時(shí),NAT-B會(huì)認(rèn)為是合法的SYN數(shù)據(jù),并允許通過,從而直接的TCP連接建立起來了。


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

    關(guān)注

    0

    文章

    151

    瀏覽量

    26592
  • NAT
    NAT
    +關(guān)注

    關(guān)注

    0

    文章

    133

    瀏覽量

    16158

原文標(biāo)題:p2p實(shí)現(xiàn)原理及打洞技術(shù)介紹

文章出處:【微信號:C_Expert,微信公眾號:C語言專家集中營】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    讀懂新能源汽車的功能安全

    電子發(fā)燒友網(wǎng)站提供《讀懂新能源汽車的功能安全.pdf》資料免費(fèi)下載
    發(fā)表于 09-04 09:22 ?2次下載

    光伏互感器p1p2正確接線法

    光伏互感器是種用于測量和保護(hù)光伏系統(tǒng)中電流的設(shè)備。正確接線對于確保光伏系統(tǒng)安全、穩(wěn)定和高效運(yùn)行至關(guān)重要。 、光伏互感器P1P2接線原理 光伏互感器P1P2的作用 光伏互感器
    的頭像 發(fā)表于 08-22 09:12 ?372次閱讀

    互感器p2朝上會(huì)影響計(jì)量嗎

    互感器P2朝上確實(shí)可能會(huì)對計(jì)量產(chǎn)生影響。通常情況下,互感器的P1P2朝向是固定的,即次側(cè)的電壓引腳P1朝上,二次側(cè)的電壓引腳P2朝下。這種
    的頭像 發(fā)表于 08-21 18:17 ?646次閱讀

    互感器p1p2穿反了有什么影響

    互感器是種用于測量高電壓或大電流的儀器,它通過將高電壓或大電流轉(zhuǎn)換為低電壓或小電流來實(shí)現(xiàn)測量。在互感器的使用過程中,P1和P2是兩個(gè)重要的端子,它們分別代表互感器的輸入端和輸出端。如
    的頭像 發(fā)表于 08-21 18:13 ?1493次閱讀

    Cyw55572 FMAC如何支持STA+AP+P2P的模式?

    客戶現(xiàn)在使用CYW55572,FMAC驅(qū)動(dòng),想知道如何實(shí)現(xiàn)STA+AP+P2P的模式,即同時(shí)可以使用STA模式,AP模式,P2P模式,麻煩幫忙指導(dǎo),謝謝
    發(fā)表于 05-29 06:15

    求助,在STM30WB55中如何讓P2P_Client同時(shí)連接P2P_Sever1和P2PSever2等多個(gè)設(shè)備?

    分別為Sever1和Sever2。目前只能實(shí)現(xiàn)Client與其中任意塊鏈接,但不能實(shí)現(xiàn)多機(jī)的鏈接。 app_conf.h中配置如下, define CFG_MAX_CONNECTIO
    發(fā)表于 04-01 06:04

    是否可以將Laird LWB+ CYW43439和WHD用于WiFi Direct/P2P模式?

    我目前正在AP和STA模式下成功使用帶有WHD的Laird LWB+ CYW43439。 但是現(xiàn)在我想在 WiFi Direct/P2P 模式下使用它。 是否可以將Laird LWB+ CYW43439和WHD用于WiFi Direct/P2P模式? 如果是這樣,我需要什
    發(fā)表于 03-01 07:47

    什么是NATNAT類型有哪些?NAT是如何工作的?NAT解決了什么問題?

    的方式來連接多個(gè)設(shè)備,而不需要為每個(gè)設(shè)備都分配個(gè)公共IP地址。通過將源IP地址和端口號映射到公共IP地址和端口號,NAT充當(dāng)了個(gè)中間人,使得設(shè)備可以通過個(gè)公共IP地址與外部網(wǎng)絡(luò)進(jìn)
    的頭像 發(fā)表于 02-04 11:03 ?2384次閱讀

    半導(dǎo)體分為哪幾種類型 怎么判斷p型半導(dǎo)體 p型半導(dǎo)體如何導(dǎo)電

    半導(dǎo)體分為哪幾種類型 怎么判斷p型半導(dǎo)體 p型半導(dǎo)體如何導(dǎo)電? 半導(dǎo)體是種具有介于導(dǎo)體和絕緣體之間特性的物質(zhì),其導(dǎo)電性能可以通過控制雜質(zhì)的加入而改變。半導(dǎo)體可以分為兩種
    的頭像 發(fā)表于 12-19 14:03 ?2890次閱讀

    讀懂車規(guī)級AEC-Q認(rèn)證

    讀懂車規(guī)級AEC-Q認(rèn)證
    的頭像 發(fā)表于 12-04 16:45 ?782次閱讀

    讀懂微力扭轉(zhuǎn)試驗(yàn)機(jī)的優(yōu)勢

    讀懂微力扭轉(zhuǎn)試驗(yàn)機(jī)的優(yōu)勢
    的頭像 發(fā)表于 11-30 09:08 ?445次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>讀懂</b>微力扭轉(zhuǎn)試驗(yàn)機(jī)的優(yōu)勢

    讀懂,什么是BLE?

    讀懂,什么是BLE?
    的頭像 發(fā)表于 11-27 17:11 ?1853次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>讀懂</b>,什么是BLE?

    p溝道和n溝道的區(qū)別 n溝道和p溝道怎樣區(qū)分?

    下什么是溝道。溝道是在半導(dǎo)體材料中形成的電子流的通道。通過在材料中創(chuàng)建和控制溝道,我們能夠控制電流的流動(dòng),從而實(shí)現(xiàn)半導(dǎo)體器件的功能。在常見的場效應(yīng)晶體管(Field-Effect Transistor, FET)中,溝道是連接源極和漏極的部分。
    的頭像 發(fā)表于 11-23 09:13 ?3898次閱讀

    基于UDP協(xié)議的P2P打洞技術(shù)詳解

    文字聊天等)。 P2P可以是種通信模式、種邏輯網(wǎng)絡(luò)模型、種技術(shù)、甚至種理念。在P2P網(wǎng)絡(luò)
    的頭像 發(fā)表于 11-13 10:52 ?2204次閱讀
    基于UDP協(xié)議的<b class='flag-5'>P2P</b>打洞技術(shù)詳解

    基于NAT穿透P2P即時(shí)通訊系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)

    電子發(fā)燒友網(wǎng)站提供《基于NAT穿透P2P即時(shí)通訊系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn).pdf》資料免費(fèi)下載
    發(fā)表于 10-27 09:44 ?0次下載
    基于<b class='flag-5'>NAT</b>穿透<b class='flag-5'>P2P</b>即時(shí)通訊系統(tǒng)的設(shè)計(jì)與<b class='flag-5'>實(shí)現(xiàn)</b>