问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

P2P穿透NAT的原理

发布网友 发布时间:2022-09-28 05:38

我来回答

1个回答

热心网友 时间:2024-11-25 16:43

NAT 俗称网络地址转换,基本 NAT 都部署在路由器或者交换机上。

主要还是IP地址的不足,使用少量的公有IP 地址代表较多的私有IP 地址的方式,将有助于减缓可用的IP地址空间的枯竭。用大白话:比如你有一个路由器(家用的那种就可以)这个路由器本身链接了公网(被分配到了一个公网的IP地址)。路由器后面有接了N多个设备,每个设备都分配到了一个私有的地址(内网地址),这些地址可以通过这个路由器和*交互(并非是代理的中继方式)。

1. 基本NAT:这种NAT下的私有IP只有少部分(并不是全部)可以和*通讯。每次这些私有地址向*发送数据的时候,NAT就会把这个数据报的 源地址IP 修改成NAT的 公网地址 (这样接收方以为这个数据报是从NAT发给我的,我后面数据报在会给这个NAT就好了),并在NAT内存下对应的 映射关系 (端口和内网私有IP的映射)。当NAT收*的数据报的时候,根据数据报的端口号找到内网的私有IP地址,将这个数据报的目的IP地址修改成内网私有IP地址(整个过程NAT负责了IP地址来回替换,辅助完成了内网机器和*设备通讯,这里的*设备有可能也是一个NAT)。如果收到的数据报在映射表中找不到对应映射,这个数据报就会被丢弃。

存在问题:基本的NAT由于不会改动端口信息,当内部2个不同机器(2个不同的私有IP)使用同样的端口会出现映射错误了。

2. NPAT:这类的NAT是在基本NAT基础上演化而来,它不仅修改 IP地址 还有 端口号 。基本可以满足NAT内全部的网络访问要求。NAT内的私有IP地址第一次向*发送数据,NAT会选一个 映射表 里面还没有被使用过的 端口号 ,然后修改 发送数据报 的 源IP地址 和 源端口号 并发送出去,并把 私有IP地址 和 源端口号 ,和修改后的 端口号 映射关系记录下来。之后这个私有IP地址发送数据会首先判别之前是不是已经有这个映射关系,如果有就继续按照映射关系修改数据报。当NAT收到外部的数据,会从映射表找到对应关系。修改数据报的 目的IP地址 和 目的端口号 ,如果映射表中没有记录这个数据报就会被丢弃了。

解决了基础NAT的端口问题:通过修改端口的可以让NAT内的多个私有IP地址可以使用相同的端口进行通信。因为NPAT更加灵活所以现在基本的NAT技术就是指的NPAT技术。

如果2台机器在同一个NAT下,那么他们可以直接通信了。

情况 1:如果2台机器有一台在NAT下另一个在*,那么只能NAT内的私有机器主动链接*机器,因为*的机器主动链接内网的机器,NAT映射表并不存在这个数据转发项,这个数据报就被丢弃了。

情况 2:如果2台机器都在不同的NAT下,那么不管哪一方发起链接请求数据报都不会到达对应的机器。这种情况非常常见。

那么最简单的方式解决上面2个问题:就是在公网部署一台 中继服务器 ,双方机器都链接这台服务器。然后 中继服务器 帮助这2台服务器转发数据。这种方式最简单也是效率最低的。

到这里P2P正式登场了:比如有下面这样的网络拓扑结构(就是上面情况2)

如果 NAT-A, IP:40.32.5.125 和 NAT-B, IP:234.12.3.8 需要直接通信的话,基本不可能,所以需要做些手段。

假设需要 手机 (图中)建立TCP链接到 电脑 (图中)需要如下手续:

**1. **由被链接方发送数据报(可以是UDP甚至是TCP的SYNC握手包)

[图片上传失败...(image-4b61ae-1528199423593)]
绿色线表示了数据报流动的方向

图中 电脑 给 NAT-A IP:40.32.5.125 / 端口:4553 发出了一个数据报,这个数据报在经过 NAT-B 的时候 源IP地址 被修改成了 NAT-B的IP地址234.12.3.8 , 源端口 被修改成了 678 。这个数据报在到达 NAT-A 的时候,在映射表中找不到 678 端口对应的内部私有IP的映射。所以这个数据报一定会被 NAT-A 丢弃掉。但是经过这次数据报发送,在 NAT-B 的映射表里面就会标记 40.32.5.125:4553 我已经发送过数据过去了,那么后面只要从这个地址发送来的数据报,我就可以转发到内网正确的设备上面。

**2. **完成第一步后,链接方可以发起数据请求

p2p可以合理的利用互联网的资源,比如两个人视频聊天。完全可以通过p2p打穿NAT后互发数据(QQ就是这么办的)。但是有的时候设备之间的直连性能很差,比如:电信的用户和移动的用户视频。这个问题是ISP厂商之间的过渡带宽太窄,就算是设备直连但是依旧速度不快。所以这里情况下需要自己搭建服务器中继(中继也不是完全无作用)。这个服务器就是网关的作用,一般有多个网卡。不同的网卡对接不同的ISP厂商,然后互相转发。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
少儿学什么舞蹈 青年学什么舞蹈好 成年人学什么舞蹈 福州企业最低工资标准 2013年厦门的底薪是多少 生产要素的需求有哪些性质 生产要素的需求有何特点? 什么是生产要素需求 微观经济学要素需求什么是条件要素需求?它和要素需求有什么不同?_百度... 养宠物的人遵守规则,是不是就能和别人平安相处呢? 去中心化 P2P 网络穿透 茂名技工学校有什么科目可读? 电气工程师请进 与饺子很配的食物CP名? cp是什么 可以吃么 木香的养殖方法和注意事项 羊的住处称为 厨师长揭秘:饭店炒土豆片的技巧,香辣过瘾一顿吃一大盘 饭店土豆片好吃的秘诀是什么? 三种交换方式的特点 电脑掉帧是什么意思? 黑苏子是什么东西 【转】这里是门,无论什么愿望都可以实现的地方。——浅论《黑之契约者... 想学习西点可以上什么大学? 对虾可以生吃么? ...市场上卖的对虾怎么吃??直接用盐水煮就可以了吧,然后煮熟用醋蘸... 国歌维,汉合唱有歌词 中华人民共和国国歌是那首? OPPO R5手机怎么恢复出厂设置 oppo r5怎么恢复出厂设置? 想学西点,请问去哪个学校学技术好? 睡觉模模糊糊的梦就半睡半醒会与现实混合在一起么?比如说:那次刚开学... 江苏将出现9级以上大风,在这样的大风天气下该注意哪些安全问题?_百度... 扁竹兰花语:幸福、喜悦 请教高手,这是什么花? 石螺隔夜能吃吗? 过夜的辣椒炒石螺可以吃吗? 煮熟石螺放水箱可以吃吗? 电脑无响应假死的解决方法 ...知道这是一对冷cp,不过我萌的不止这一对,还有轰爆和 龙族第一部里面路明非轰爆楚子航恺撒时路明非说了什么?就是“逆... 《新元史》卷八·本纪第八(6) 而巧过其师的而是什么意思 如何把照片拍成复古状? 《纪昌学射》理解下面“而"的用法。急急急急急急急 蹲防空洞要准备什么物资 请问防空洞是什么东西 请问一下防空洞是什么东西 纪昌学射的译文 "巧过其师”是什么意思