P2P打洞原理

tcp打洞

首先我们明确现在我们有的设备:
1、客户端A,网关NAT-A
2、客户端B,网关NAT-B
3、服务器S

这些设备明确之后,就可以介绍TCP打洞的过程:
1、首先服务器S开启两个服务监听,一个主连接端口,和一个协助打洞端口
2、A通过主连接端口连接服务器S,B通过主连接端口连接服务器S,这个是正常的服务器通信
3、当A需要和B进行直接连接时,首先A去连接服务器S的协助打洞端口,并向服务器发送和B的协助连接请求,服务器S收到请求后,向B发送A的外网地址(也就是NAT-A的地址)
4、B收到服务器S发来的A的外网地址后,就向A发数据,此时由于A并没有主动向B发过数据,NAT-A会认为这些数据是非法请求,会抛弃掉,并且B开启监听服务,等待A的连接,并告诉服务器它准备好了
5、服务器收到了B的准备连接的消息之后,就通过主连接把B的外网地址告诉A,A就可以直接去连接B了(因为B之前在第4部就向A发送过数据了,所以NAT-B会直接将A发来的数据转发给B),此时就可以成功连接上了

Udp打洞

udp打洞和tcp类似,只是tcp规定同一监听端口只能绑定一个socket套接字,而udp规定一个监听端口可以绑定多个socket套接字,所以udp不需要开启额外的协助连接端口,只需要开启一个端口就可以了
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
NAT大致分为下面四类 1) Full Cone 这种NAT内部的机器A连接过外网机器C后,NAT会打开一个端口.然后外网的任何发到这个打开的端口的UDP数据报都可以到达A.不管是不是C发过来的. 例如 A:192.168.8.100 NAT:202.100.100.100 C:292.88.88.88 A(192.168.8.100:5000) -> NAT(202.100.100.100 : 8000) -> C(292.88.88.88:2000) 任何发送到 NAT(202.100.100.100:8000)的数据都可以到达A(192.168.8.100:5000) 2) Restricted Cone 这种NAT内部的机器A连接过外网的机器C后,NAT打开一个端口.然后C可以用任何端口和A通信.其他的外网机器不行. 例如 A:192.168.8.100 NAT:202.100.100.100 C:292.88.88.88 A(192.168.8.100:5000) -> NAT(202.100.100.100 : 8000) -> C(292.88.88.88:2000) 任何从C发送到 NAT(202.100.100.100:8000)的数据都可以到达A(192.168.8.100:5000) 3) Port Restricted Cone 这种NAT内部的机器A连接过外网的机器C后,NAT打开一个端口.然后C可以用原来的端口和A通信.其他的外网机器不行. 例如 A:192.168.8.100 NAT:202.100.100.100 C:292.88.88.88 A(192.168.8.100:5000) -> NAT(202.100.100.100 : 8000) -> C(292.88.88.88:2000) C(202.88.88.88:2000)发送到 NAT(202.100.100.100:8000)的数据都可以到达A(192.168.8.100:5000) 以上三种NAT通称Cone NAT.我们只能用这种NAT进行UDP打洞. 4) Symmetic 对于这种NAT.连接不同的外部目标.原来NAT打开的端口会变化.而Cone NAT不会.虽然可以用端口猜测.但是成功的概率很小.因此放弃这种NAT的UDP打洞.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值