1. NAT分类

根据Stun协议(RFC3489),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打洞.

2. UDP hole punching

对于Cone NAT.要采用UDP打洞.需要一个公网机器C来充当”介绍人”.内网的A,B先分别和C通信.打开各自的NAT端口.C这个时候知道A,B的公网IP:Port. 现在A和B想直接连接.比如A给B发.除非B是Full Cone.否则不能通信.反之亦然.但是我们可以这样.

A要连接B.A给B发一个UDP包.同时.A让那个介绍人给B发一个命令,让B同时给A发一个UDP包.这样双方的NAT都会记录对方的IP,然后就会允许互相通信.

3. 同一个NAT后面的情况

如果A,B在同一个NAT后面.如果用上面的技术来进行互连.那么如果NAT支持loopback(就是本地到本地的转换),A,B可以连接,但是比较浪费带宽和NAT.有一种办法是,A,B和介绍人通信的时候,同时把自己的local IP也告诉服务器.A,B通信的时候,同时发local ip和公网IP.谁先到就用哪个IP.但是local ip就有可能不知道发到什么地方去了.比如A,B在不同的NAT后面但是他们各自的local ip段一样.A给B的local IP发的UDP就可能发给自己内部网里面的某某某了.

最新文章

  1. AI (Adobe Illustrator)详细用法(二)
  2. How to create QTP Shared Object Repository
  3. jq实现地址级联效果
  4. api 翻译之AsyncTask
  5. 网易云课堂_C++程序设计入门(上)_第1单元:C++概览_第1单元作业 - 写代码 - 互评 (难度:易)
  6. 从零開始开发Android版2048 (四) 分数、重置、结束
  7. Linux在简短而经常使用的命令
  8. 解决IE浏览器“无法显示此网页”的问题
  9. win7下 mysql安装(mysql-5.7.18-winx64.zip)
  10. 题解-POI2014 Supercomputer
  11. Mantis:Mantis rest api url 404 Not Found.解决过程纪录
  12. js给页面添加回车监测事件,实现回车登录功能
  13. 使用 curses 函数库管理基于文本的屏幕
  14. vander范德蒙德行列式
  15. thinkPHP框架 简单的删除和修改数据的做法 和 模板继承的意思大概做法
  16. Hive学习之路 (二十一)Hive 优化策略
  17. Windows 10 下 PostgreSQL 生成 UUID(Guid)
  18. 树莓派 Zero W+温度传感器DS18B20
  19. 删除iptables nat 规则
  20. python面向对象中类对象、实例对象、类变量、实例变量、类方法、实例方法、静态方法

热门文章

  1. ORACLE之UTL_FILE包详解
  2. MongoDB新增及查询数据(一)
  3. JavaScript中的property和attribute
  4. 小米Web前端JavaScript面试题
  5. Mathematica修改默认字体
  6. Oracle dmp文件导入(还原)到不同的表空间和不同的用户下
  7. [推荐]PaaS技术知识贴
  8. java中static{}语句块详解
  9. 电子病历,到底是用BS还是CS
  10. ftp如何预览图片 解决方案