LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網站管理員

UDP打洞,穿透NAT

admin
2014年1月26日 14:22 本文熱度 5792

前天編程做了一下UDP打洞的實驗,今天特寫了一篇文章總結一下。
我們知道網絡上兩個主機進行通信,如果其中一臺主機擁有公網IP那么,那么進行會話是比較簡單的,但是如果兩臺主機是位于不同內網之中的,那么應該如何進行通信呢。一種想法是再找一臺公網的服務器,用來轉發(fā)信息,但是這有一個問題,就是會給服務器帶來壓力,因此我們就來談談一種用于不同內網中的主機互相通信的一個解決方案——NAT打洞。
原理還是比較簡單的,我們先了解一下什么是“NAT的洞”。當處于內網中的一臺主機(ClientA/192.168.1.128)向一個公網的服務器(Server)發(fā)送數(shù)據(jù)時,這時NAT(NAT1)將會打開一個臨時性的端口用于與公網的服務器進行通信,并且會把那個內網主機發(fā)送出的IP數(shù)據(jù)報的頭部中源IP地址改為NAT的公網IP(218.7.32.28),將TCP或UDP數(shù)據(jù)報中源端口(2347)改為那個臨時端口(26756)這樣就實現(xiàn)了由“192.168.1.128:2347”到“218.7.32.28:26756”的源地址源端口的轉換。這個數(shù)據(jù)包到達公網服務器后,服務器就可以根據(jù)這個包的頭部信息進行回復。當服務器的數(shù)據(jù)包到達NAT后,NAT在將這個數(shù)據(jù)發(fā)送到內網主機192.168.1.128的2347端口。那么這個NAT上的26756端口我們就稱作“洞”。如果這個NAT不是Full Cone NAT的話(其實大多數(shù)的NAT確實不是這種類型的),那么我們說這個“洞”是有方向性的。一個洞應該會指向一個(也可以是多個)公網主機的IP地址。比如上面說的例子,在NAT1上打的洞是指向Server的IP地址。來自其他公網主機發(fā)向這個洞(也就是218.7.32.28:26756)的數(shù)據(jù)包會被非Full Cone類型的NAT所丟棄。所以如果有另一臺處于另一內網的主機(ClientB/192.168.0.5)向218.7.32.28:26756直接發(fā)送數(shù)據(jù)的話,同樣也會被NAT1丟棄。
那么如何建立ClientA和ClientB的直接會話呢?
網絡環(huán)境描述:
內網1NAT:NAT1/218.7.32.28
內網1中一臺主機:ClientA/192.168.1.128
內網2NAT:NAT2/218.7.31.221
內網2中一臺主機:ClientB/192.168.0.5
公網服務器:Server
首先讓ClientA和ClientB登錄到服務器Server(假如兩臺主機都采用2347端口),此時NAT1和NAT2會分別為ClientA和ClientB打開一個指向Server的洞(NAT1上218.7.32.28:26756和NAT2上218.7.31.221:27550)。服務器應改記錄這兩個客戶端的信息(關鍵是那兩個洞的信息)。當ClientA與ClientB要建立會話時,ClientA首先用2347端口向NAT2的洞發(fā)送一個數(shù)據(jù)包,當然這個數(shù)據(jù)包會被NAT2所丟棄,但是由于這是從NAT1內部向外部發(fā)送數(shù)據(jù),所以NAT1為ClientA打開了一個指向NAT2的洞。而且這個新洞與原來NAT1上指向Server的舊洞的是同一個洞(因為是同一個端口26756),所以這里可以說這個洞具有了兩個方向,同時指向Server和NAT2。這時ClientA應該通知Server,告訴ClientB,現(xiàn)在可以向NAT1的那個洞(218.7.32.28:26756)發(fā)送數(shù)據(jù)包了。當ClientB向NAT1的那個洞發(fā)送數(shù)據(jù)以后,NAT2也為ClientB打了一個指向NAT1的洞,這是可以說ClientA與ClientB的會話就建立完成了,他們可以不依賴Server進行通信了。如果以后ClientA和ClientB還需要建立其他會話 ,那么這個牽線的“媒人”可以不是Server,而可以是ClientA或ClientB了。
UDP打洞可以實現(xiàn)不同內網內的主機進行通信,而且實施性比較高,一般用于P2P通信。這也就是為什么常會看見騰訊QQ在開始傳輸文件時會顯示“UDP連接已經建立”了。


該文章在 2014/1/26 14:22:38 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業(yè)的專業(yè)生產管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內大量中小企業(yè)的青睞。
點晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業(yè)務管理,結合碼頭的業(yè)務特點,圍繞調度、堆場作業(yè)而開發(fā)的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點晴WMS倉儲管理系統(tǒng)提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統(tǒng),標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

黄频国产免费高清视频,久久不卡精品中文字幕一区,激情五月天AV电影在线观看,欧美国产韩国日本一区二区
亚洲欧美中文字幕在线一区二区 | 日韩激情精品一区二区三区 | 免费h片网站在线观看视频 原创国产中文AV | 亚洲欧美国产日韩中文字幕 | 在线精品自在视频观看 | 在线观看1024国产 |