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

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

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

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

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

p2p實現(xiàn)原理

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

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

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

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

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

下面是NAT的幾種類型

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

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

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


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

    關注

    0

    文章

    151

    瀏覽量

    26635
  • NAT
    NAT
    +關注

    關注

    0

    文章

    137

    瀏覽量

    16195

原文標題:p2p實現(xiàn)原理及打洞技術介紹

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

收藏 人收藏

    評論

    相關推薦

    臺電新品P50 AI平板電腦即將上市

    本次P50AI平板電腦誕生過程得益于臺電與全志科技再次深度聯(lián)袂合作,并在臺電新品P50AI上首發(fā)搭載全志A733處理器。賦能AI,提高消費者使用體驗!功能性前瞻,
    的頭像 發(fā)表于 10-24 10:23 ?231次閱讀

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

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

    光伏互感器p1p2正確接線法

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

    互感器p2朝上會影響計量嗎

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

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

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

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

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

    求助,在STM30WB55中如何讓P2P_Client同時連接P2P_Sever1和P2PSever2等多個設備?

    分別為Sever1和Sever2。目前只能實現(xiàn)Client與其中任意塊鏈接,但不能實現(xiàn)多機的鏈接。 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

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

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

    半導體分為哪幾種類型 怎么判斷p型半導體 p型半導體如何導電

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

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

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

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

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

    讀懂,什么是BLE?

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

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

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

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

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