p2p内网穿透技术-udp打洞

栏目: 服务器 · 发布时间: 5年前

内容简介:在公司如何访问家里的电脑?实现方法有很多,其它p2p传输文件最快,能否实现?完全圆锥型NAT: 无条件转发

在公司如何访问家里的电脑?实现方法有很多,其它p2p传输文件最快,能否实现?

udp打洞原理

假设有两台分别处于各自的私有网络中的主机:A和B;N1和N2是两个网络的NAT设备,分别拥有IP地址P1和P2;S是一个使用了一个众所周知的、从全球任何地方都能访问得到的IP地址的公共服务器

步骤一:A和B分别和S建立UDP连接;NAT设备N1和N2创建UDP转换状态并分配临时的外部端口号

步骤二:S检查UDP包,看A和B的端口是否是正在被使用的(否则的话N1和N2应该是应用了端口随机分配,这会让路由验证变得更麻烦)

步骤三:如果端口不是随机化的,那么A和B各自选择端口X和Y,并告知S。S会让A发送UDP包到P2:Y,让B发送UDP包到P1:X

步骤四:A和B通过转换好的IP地址和端口直接联系到对方的NAT设备;

p2p内网穿透技术-udp打洞

udp打洞成功前提条件--非对称NAT

完全圆锥型NAT: 无条件转发

受限圆锥型NAT:  忽略掉其它主机的数据包(要求来源ip一直)

端口受限圆锥型NAT: 更进一步地要求源端口(上例中是 2727)必须跟之前发出的数据包的目的端口一致(要求来源ip和端口)

对称NAT: 丢弃报文,拒绝转发(每次连接端口会变)

对称NAT理论上可以使用端口预测,但是基本上用不了。现在国内几个宽带运行商都是使用对称NAT,所以udp打洞不可行。

记得之前上学的时候p2p共享软件很多,后来都销声匿迹,应该是被管控了。

socat测试udp打洞

下面是socat打洞的例子,试过在公司与家里之间打洞,用不了被现实了

https://blog.lilydjwg.me/2012/8/28/udp-hole-punching-experiment.35350.html

frp测试udp打洞

frp采用xtcp协议,试过同样用不了。stcp可以用,但是不是p2p,要经过中间转发。

检查nat类型?

#python直接用pynat包
pip install pynat

pynat

C:\Users\wyq>pynat
Network type: Symmetric NAT   #对称nat
Internal address: 192.168.50.169:54320
External address: xxx.xxx.xxx.xxx:61195

内网穿透可行方法

方法 描述 实现条件 实际是否可行
p2p udp打洞 非对称nat 不可行。宽带基本都是对称nat。除非在自己公网ip上提供p2p穿透
ddns 路由器使用有公网ip 宽带提供了公网ip 不可行。路由器基本没有公网ip
端口转发 将端口映射到公网ip 需要公网ip 可行
vpn 要求有公网ip节点,运行vpn服务端 需要公网ip 可行

参考来源

http://www.yongqingking.top/vps/2018/11/25/dig-hole.html

此生必看的科学实验-水知道答案

《了凡四训》详解之改过之法

印光大师十念法(胡小林主讲第1集)

精神病为什么治不好

百病之源


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

游戏编程入门

游戏编程入门

莫里森 / 人民邮电出版社 / 2005-9 / 49.00元

本书介绍如何设计和构建自己的计算机游戏。书中从零开始,引导读者开发一个“即插即用”的游戏引擎,并基于该引擎,循序渐进地开发7个完整的游戏。全书分为8个部分,共24章,内容包括游戏编程基础知识、如何与玩家交互、使用子画面动画、使用声音和音乐、高级动画、游戏人工智能、增添游戏的趣味性和附加练习。此外,在随书光盘中提供有附录,包括C++语言和windows编程的入门指导、游戏开发工具以及游戏图形创建的介......一起来看看 《游戏编程入门》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

随机密码生成器
随机密码生成器

多种字符组合密码

html转js在线工具
html转js在线工具

html转js在线工具