p2p内网穿透技术
  

sailyang 3333

{{ttag.title}}
在公司如何访问家里的电脑?实现方法有很多,其它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设备;

udp打洞成功前提条件–非对称NAT
完全圆锥型NAT: 无条件转发
受限圆锥型NAT: 忽略掉其它主机的数据包(要求来源ip一直)
端口受限圆锥型NAT: 更进一步地要求源端口(上例中是 2727)必须跟之前发出的数据包的目的端口一致(要求来源ip和端口)
对称NAT: 丢弃报文,拒绝转发(每次连接端口会变)
对称NAT理论上可以使用端口预测,但是基本上用不了。现在国内几个宽带运行商都是使用对称NAT,所以udp打洞不可行。

记得之前上学的时候p2p共享软件很多,后来都销声匿迹,应该是被管控了。
socat测试udp打洞。
下面是socat打洞的例子,试过在公司与家里之间打洞,用不了被现实了
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

打赏鼓励作者,期待更多好文!

打赏
暂无人打赏

好心情能长寿 发表于 2018-12-5 20:30
  
看不太懂
yuan666 发表于 2018-12-6 09:35
  
高端 看不懂。。。
发表新帖
热门标签
全部标签>
西北区每日一问
技术盲盒
每日一问
技术笔记
干货满满
GIF动图学习
通用技术
标准化排查
SDP百科
产品连连看
技术咨询
技术圆桌
社区新周刊
信服课堂视频
功能体验
2023技术争霸赛专题
秒懂零信任
自助服务平台操作指引
畅聊IT
在线直播
新版本体验
技术晨报
安装部署配置
sangfor周刊
VPN 对接
专家问答
高手请过招
升级&主动服务
答题自测
MVP
网络基础知识
升级
安全攻防
上网策略
测试报告
日志审计
问题分析处理
流量管理
每日一记
运维工具
云计算知识
用户认证
原创分享
解决方案
项目案例
SANGFOR资讯
专家分享
技术顾问
信服故事
功能咨询
终端接入
授权
设备维护
资源访问
地址转换
虚拟机
存储
迁移
加速技术
排障笔记本
产品预警公告
玩转零信任
信服圈儿
S豆商城资讯
技术争霸赛
「智能机器人」
追光者计划
深信服技术支持平台
社区帮助指南
答题榜单公布
纪元平台
卧龙计划
华北区拉练
天逸直播
以战代练
山东区技术晨报
文档捉虫活动
齐鲁TV
华北区交付直播
每周精选
2024年技术争霸赛
北京区每日一练
场景专题
故障笔记
排障那些事
高频问题集锦

本版版主

461
247
13

发帖

粉丝

关注

本版达人

feeling

本周分享达人

新手29676...

本周提问达人