RTMFP connectivity Checker(NAT检查工具):
http://cc.rtmfp.net/
由于公网IP有限,NAT几乎是无处不在。比如我们在家里,牵一个ADSL,用Modem拨号得到一个公网IP,然后在Modem后面再接一个路由使得多个设备能同时上网。路由会有一个公网IP一个私网IP,然后家里的其它设备都用的是私网IP。此时路有器就要完成一个很重要的职责:对于进出它的包做网络地址转换。
NAT是在传输层及以上做的,传输层最主要的2个协议是TCP和UDP,下面只考虑UDP。对于UDP而言,每个包都有很基本的4个要素:src ip、src port、dst ip、dst port。根据在做NAT的时候是否保留src ip和src port,可以把NAT分为这么三种:
Cone: 将src ip映射到一个固定的IP,并且将src port映射到一个固定的Port,无论dst ip和dst port是什么。假如我从192.168.0.2:5000,通过路由器发一个UDP包给66.66.88.88:4000端口,而路由器把这个包的src ip和src port翻译成了173.245.73.182:5000。那么在此后一段时间内,无论我从192.168.0.2:5000往外面的任意IP、任意端口发包,src ip、src port都会被翻译成173.245.73.182:5000。
Single IP address, symmetric:将src ip映射到一个固定的IP,将src port映射到一个随机的port,但是保证对于相同的(dst ip,dst port), src port始终相同。(否则双方没法通话啊,回来的包回给哪个端口呢?)举例:假如我从192.168.0.2:5000,通过路由器发一个UDP包给66.66.88.88:4000端口,而路由器把这个包的src ip和src port翻译成了173.245.73.182:5000。那么在此后一段时间内,无论我从192.168.0.2:5000往外面的任意IP、任意端口发包,src ip都会被翻译成173.245.73.182,但是src port嘛,可就说不准了。
Multiple IP address, symmetric:与上面类似,但是src ip可能会被映射到多个IP中的一个。最典型的就是假如你的网关做了双线接入,那么你访问电信的资源就会走电信的那个IP出去,你访问网通的资源就会走网通的IP出去。这种策略对于做P2P来说简直就是恶梦啊!!
上面只说了发,下面说收。根据对收到的包的过滤限制,可能把Cone分为3种:
Full Cone: 不对收到的包的IP端口做任何限制. 这种NAT通常被称为static NAT,在外面看就像是一个透明代理一样。比如我在192.168.0.1上,用iptables把80端口映射到192.168.0.2的8080上。那么无论从哪来的包,都会被转发过去。
Restricted Cone: Restricted Cone会对收到的包的IP做限制。假如我从192.168.0.2:5000,通过路由器173.245.73.182:5000端口发给173.245.88.88:4000端口。然后对方从173.245.88.88:4000给173.245.73.182:5000回了一个包,那么毫无疑问我们的路由器应该接受这个包,并转发给192.168.0.2:5000。假设有另外一台我根本不认识的机器,比如66.66.99.99要给173.245.73.182:5000发包,那么我们的路由器就会丢弃这个包。
Port Restricted Cone: 它就是在Restricted Cone的基础上对端口也做了限制。假如我从192.168.0.2:5000,通过路由器173.245.73.182:5000端口发给173.245.88.88:4000端口。然后对方从173.245.88.88:4000给173.245.73.182:5000回了一个包,那么毫无疑问我们的路由器应该接受这个包。如果你换个端口,从173.245.88.88:6000给173.245.73.182:5000回包,我们的路由器就会丢弃。
对于Cone,可采用很简单的NAT穿透的方式建立P2P直连。
RTMFP中的P2P打洞过程:
假设一共三个角色:Server、Initiator(Peer1)、Target(Peer2)。Target已经与Server建立RTMFP连接。
上图中曲线代表NAT设备。
在连接建立之后,Target就有了一个唯一的PeerID,Server通过UDP包头可以得知这个Peer的公网IP和端口。
此外,在建立连接后,Target还会通过一个名为SetPeerInfo的RPC调用,将自己的IP、端口号汇报给Server。
例如:
2012-06-20 17:17:08 9640 (i)2581173 rtmfp send message, session: 0BC276C8 flow: 056A5C00 kMsgCmdEx idByte=17 streamId=0 time=84 trxId=0 kEncodingAMF0 setPeerInfo cmdData=( kNullType ) arg0=( kStringType "192.168.146.1:61920" ) arg1=( kStringType "192.168.15.1:61920" ) arg2=( kStringType "10.4.8.84:61920" )
然后Server就会维护一张映射表,key是PeerID,value是地址(IP和端口号)列表。
现在Initiator要连接Target。
Initiator首先向Server发InitiatorHello请求,其中带上Target的peerID。Initiator此时并不知道Peer2的地址,它只知道Target的PeerID。
Server向Initiator回复一个Redirect消息,里面包含Target的公网IP端口(通过UDP包头可以得到)、以及Target的所有内网IP端口, 如下面这条日志所示:
2012-06-20 17:17:17 9640 (d)0000000 core redirect { epd: 210fce584f9dcf7962d475af4128437d71233bb99f8debd2da8f9f558d60cf6071bb tag: 24dfff0da10b24d3b33af1931e0cf699 fromAddr: 173.245.73.182:61922 instanceInterfaceID: 2 } to { derived 66.66.99.99:61920;reported 192.168.146.1:61920;reported 192.168.15.1:61920;relay 66.66.88.88:19351;}
RTMFP Redirect消息就像HTTP的302一样,收到者(Initiator)需要向新地址重新建立连接,即发送InitiatorHello包。这里面所说的relay应该是经Server中转的意思,具体流程我还不明白。
同时,Server给Target发一个Forward Message,里面包含Peer1的公网IP端口。 如下面这条日志所示:
2012-06-20 17:17:17 9640 (d)0000000 core forward { epd: 210fce584f9dcf7962d475af4128437d71233bb99f8debd2da8f9f558d60cf6071bb tag: 24dfff0da10b24d3b33af1931e0cf699 fromAddr: 173.245.73.182:61922 instanceInterfaceID: 2 } -
其中epd就是Initiator的peerID,173.245.73.182:61922 就是Initiator公网IP端口。
Forward Message就像servlet里面的forward一样,收到者(Target)需要直接给原始的请求者(Initiator)回下一个握手包(即Response Hello)。
对Initiator来说,哪个地址先回给它第一个Response Hello包,它就跟哪个地址继续握手。
假设Initiator和Target处于同一个NAT中,那么会尽量通过redirect消息进行直连,以后的交互就跟NAT没有关系。但是怎么控制这个的呢?我还不明白。
假设Initiator和Target处于不同的NAT之中,两个NAT类型都是Port Restricted Cone,那么Peer1收到Redirect消息的时候,然后向Peer2发送InitiatorHello的时候,就在Peer1的NAT上打了一个洞。虽然这个InitiatorHello也许会被Peer2的防火墙拦掉,但是没有关系,正因为有了这个洞,Peer2的ResponseHello才能进来。
假设Initiator是处于symmetric single IP NAT之后,那么Server给Target的地址其实是一个错误的地址(端口号不对),所以Target收到Forward消息后所作的那个ResponseHello包,Initiator根本就收不到(Initiator没有用那个端口给Target发过包)。但是假如Target是Restricted Cone,发完这个ResponseHello之后它就能接收来自Initiator的任何端口包。所以它们能接着Redirect消息之后的流程继续走下去。
如果很不幸,Target也是处于symmetric single IP NAT之后,那么Target在回复Forward消息的时候就要采用猜端口的方式,给Initiator多发几个ResponseHello包,如果有幸猜中了Initiator答复Redirect消息时所采用的端口,那么两者就可以连接起来了。不过Flash好像没有这么做。
NAT检查工具:http://cc.rtmfp.net/
Public UDP port number same as local UDP port number:这个是指NAT是否将src port做了转换。
Can receive from same IP address, same UDP port number:这个值应当永远是Yes。因为如果连这个检查都通不过,连接根本就建立不起来。
Can receive from same IP address, different UDP port number:如果这个值是true,说明是Port Restricted Cone,它会把出去的包的dst port记录下来,然后收到包时检查port number。
Can receive from different IP address, different UDP port number:如果这个值是true,说明是Restricted Cone,即它不对端口号做检查。
Can send to different IP address after server introduction:这个值应当永远是Yes。
Source IP address is preserved from original connection:这个是看server收到的包是否都来自于同一个IP。这个有一定的假阳性在里面,只要有一次为false,就说明用的是Multiple IP address symmetric NAT。
Source UDP port number is preserved from original connection:true说明是cone NAT,false说明是symmetric NAT。
我自制了一张连通性图:
Restricted Cone Port Restricted Cone symmetric single IP symmetric multiple IP
Restricted Cone Yes Yes Yes No
Port Restricted Cone Yes Yes No No
symmetric single IP Yes No No No
symmetric multiple IP No No No No
http://cc.rtmfp.net/
由于公网IP有限,NAT几乎是无处不在。比如我们在家里,牵一个ADSL,用Modem拨号得到一个公网IP,然后在Modem后面再接一个路由使得多个设备能同时上网。路由会有一个公网IP一个私网IP,然后家里的其它设备都用的是私网IP。此时路有器就要完成一个很重要的职责:对于进出它的包做网络地址转换。
NAT是在传输层及以上做的,传输层最主要的2个协议是TCP和UDP,下面只考虑UDP。对于UDP而言,每个包都有很基本的4个要素:src ip、src port、dst ip、dst port。根据在做NAT的时候是否保留src ip和src port,可以把NAT分为这么三种:
Cone: 将src ip映射到一个固定的IP,并且将src port映射到一个固定的Port,无论dst ip和dst port是什么。假如我从192.168.0.2:5000,通过路由器发一个UDP包给66.66.88.88:4000端口,而路由器把这个包的src ip和src port翻译成了173.245.73.182:5000。那么在此后一段时间内,无论我从192.168.0.2:5000往外面的任意IP、任意端口发包,src ip、src port都会被翻译成173.245.73.182:5000。
Single IP address, symmetric:将src ip映射到一个固定的IP,将src port映射到一个随机的port,但是保证对于相同的(dst ip,dst port), src port始终相同。(否则双方没法通话啊,回来的包回给哪个端口呢?)举例:假如我从192.168.0.2:5000,通过路由器发一个UDP包给66.66.88.88:4000端口,而路由器把这个包的src ip和src port翻译成了173.245.73.182:5000。那么在此后一段时间内,无论我从192.168.0.2:5000往外面的任意IP、任意端口发包,src ip都会被翻译成173.245.73.182,但是src port嘛,可就说不准了。
Multiple IP address, symmetric:与上面类似,但是src ip可能会被映射到多个IP中的一个。最典型的就是假如你的网关做了双线接入,那么你访问电信的资源就会走电信的那个IP出去,你访问网通的资源就会走网通的IP出去。这种策略对于做P2P来说简直就是恶梦啊!!
上面只说了发,下面说收。根据对收到的包的过滤限制,可能把Cone分为3种:
Full Cone: 不对收到的包的IP端口做任何限制. 这种NAT通常被称为static NAT,在外面看就像是一个透明代理一样。比如我在192.168.0.1上,用iptables把80端口映射到192.168.0.2的8080上。那么无论从哪来的包,都会被转发过去。
Restricted Cone: Restricted Cone会对收到的包的IP做限制。假如我从192.168.0.2:5000,通过路由器173.245.73.182:5000端口发给173.245.88.88:4000端口。然后对方从173.245.88.88:4000给173.245.73.182:5000回了一个包,那么毫无疑问我们的路由器应该接受这个包,并转发给192.168.0.2:5000。假设有另外一台我根本不认识的机器,比如66.66.99.99要给173.245.73.182:5000发包,那么我们的路由器就会丢弃这个包。
Port Restricted Cone: 它就是在Restricted Cone的基础上对端口也做了限制。假如我从192.168.0.2:5000,通过路由器173.245.73.182:5000端口发给173.245.88.88:4000端口。然后对方从173.245.88.88:4000给173.245.73.182:5000回了一个包,那么毫无疑问我们的路由器应该接受这个包。如果你换个端口,从173.245.88.88:6000给173.245.73.182:5000回包,我们的路由器就会丢弃。
对于Cone,可采用很简单的NAT穿透的方式建立P2P直连。
RTMFP中的P2P打洞过程:
假设一共三个角色:Server、Initiator(Peer1)、Target(Peer2)。Target已经与Server建立RTMFP连接。
上图中曲线代表NAT设备。
在连接建立之后,Target就有了一个唯一的PeerID,Server通过UDP包头可以得知这个Peer的公网IP和端口。
此外,在建立连接后,Target还会通过一个名为SetPeerInfo的RPC调用,将自己的IP、端口号汇报给Server。
例如:
2012-06-20 17:17:08 9640 (i)2581173 rtmfp send message, session: 0BC276C8 flow: 056A5C00 kMsgCmdEx idByte=17 streamId=0 time=84 trxId=0 kEncodingAMF0 setPeerInfo cmdData=( kNullType ) arg0=( kStringType "192.168.146.1:61920" ) arg1=( kStringType "192.168.15.1:61920" ) arg2=( kStringType "10.4.8.84:61920" )
然后Server就会维护一张映射表,key是PeerID,value是地址(IP和端口号)列表。
现在Initiator要连接Target。
Initiator首先向Server发InitiatorHello请求,其中带上Target的peerID。Initiator此时并不知道Peer2的地址,它只知道Target的PeerID。
Server向Initiator回复一个Redirect消息,里面包含Target的公网IP端口(通过UDP包头可以得到)、以及Target的所有内网IP端口, 如下面这条日志所示:
2012-06-20 17:17:17 9640 (d)0000000 core redirect { epd: 210fce584f9dcf7962d475af4128437d71233bb99f8debd2da8f9f558d60cf6071bb tag: 24dfff0da10b24d3b33af1931e0cf699 fromAddr: 173.245.73.182:61922 instanceInterfaceID: 2 } to { derived 66.66.99.99:61920;reported 192.168.146.1:61920;reported 192.168.15.1:61920;relay 66.66.88.88:19351;}
RTMFP Redirect消息就像HTTP的302一样,收到者(Initiator)需要向新地址重新建立连接,即发送InitiatorHello包。这里面所说的relay应该是经Server中转的意思,具体流程我还不明白。
同时,Server给Target发一个Forward Message,里面包含Peer1的公网IP端口。 如下面这条日志所示:
2012-06-20 17:17:17 9640 (d)0000000 core forward { epd: 210fce584f9dcf7962d475af4128437d71233bb99f8debd2da8f9f558d60cf6071bb tag: 24dfff0da10b24d3b33af1931e0cf699 fromAddr: 173.245.73.182:61922 instanceInterfaceID: 2 } -
其中epd就是Initiator的peerID,173.245.73.182:61922 就是Initiator公网IP端口。
Forward Message就像servlet里面的forward一样,收到者(Target)需要直接给原始的请求者(Initiator)回下一个握手包(即Response Hello)。
对Initiator来说,哪个地址先回给它第一个Response Hello包,它就跟哪个地址继续握手。
假设Initiator和Target处于同一个NAT中,那么会尽量通过redirect消息进行直连,以后的交互就跟NAT没有关系。但是怎么控制这个的呢?我还不明白。
假设Initiator和Target处于不同的NAT之中,两个NAT类型都是Port Restricted Cone,那么Peer1收到Redirect消息的时候,然后向Peer2发送InitiatorHello的时候,就在Peer1的NAT上打了一个洞。虽然这个InitiatorHello也许会被Peer2的防火墙拦掉,但是没有关系,正因为有了这个洞,Peer2的ResponseHello才能进来。
假设Initiator是处于symmetric single IP NAT之后,那么Server给Target的地址其实是一个错误的地址(端口号不对),所以Target收到Forward消息后所作的那个ResponseHello包,Initiator根本就收不到(Initiator没有用那个端口给Target发过包)。但是假如Target是Restricted Cone,发完这个ResponseHello之后它就能接收来自Initiator的任何端口包。所以它们能接着Redirect消息之后的流程继续走下去。
如果很不幸,Target也是处于symmetric single IP NAT之后,那么Target在回复Forward消息的时候就要采用猜端口的方式,给Initiator多发几个ResponseHello包,如果有幸猜中了Initiator答复Redirect消息时所采用的端口,那么两者就可以连接起来了。不过Flash好像没有这么做。
NAT检查工具:http://cc.rtmfp.net/
Public UDP port number same as local UDP port number:这个是指NAT是否将src port做了转换。
Can receive from same IP address, same UDP port number:这个值应当永远是Yes。因为如果连这个检查都通不过,连接根本就建立不起来。
Can receive from same IP address, different UDP port number:如果这个值是true,说明是Port Restricted Cone,它会把出去的包的dst port记录下来,然后收到包时检查port number。
Can receive from different IP address, different UDP port number:如果这个值是true,说明是Restricted Cone,即它不对端口号做检查。
Can send to different IP address after server introduction:这个值应当永远是Yes。
Source IP address is preserved from original connection:这个是看server收到的包是否都来自于同一个IP。这个有一定的假阳性在里面,只要有一次为false,就说明用的是Multiple IP address symmetric NAT。
Source UDP port number is preserved from original connection:true说明是cone NAT,false说明是symmetric NAT。
我自制了一张连通性图:
Restricted Cone Port Restricted Cone symmetric single IP symmetric multiple IP
Restricted Cone Yes Yes Yes No
Port Restricted Cone Yes Yes No No
symmetric single IP Yes No No No
symmetric multiple IP No No No No
发表评论
-
Linux下实现免密码登录(超详细)
2017-07-25 17:42 6751.Linux下生成密钥 ssh-keygen的命令手 ... -
Linux下用SCP无需输入密码传输文件
2017-06-01 12:13 533在Linux环境下,两台主机之间传输文件一般使用scp命令, ... -
linux下修改mysql密码
2017-03-02 12:53 464以root用户登录,命令:mysql -uroot -p 回车 ... -
docker安装与启动
2017-02-22 12:30 480安装docker [root@localhost /]# ... -
centOS升级Python2.6到Python2.7并安装pip
2016-09-26 13:29 412貌似CentOS 6.X系统默认安装的Python都是2.6 ... -
Htop安装
2016-09-21 13:47 466下载 ftp://rpmfind.net/linux ... -
HTTP_Load测试web服务器的吞吐量和负载
2016-09-20 22:53 1072下载:http_load (百度云盘) 解压并编译: ... -
Nginx压力测试工具之WebBench
2016-09-20 22:11 419在Apache中有自带的ab命令可以测试服务的压力,而ng ... -
linux下取代top的进程管理工具htop
2016-09-18 16:41 493一、htop 简介 This is htop, an in ... -
Linux查看系统配置常用命令
2016-09-17 15:52 673系统 # uname -a # 查看内核/操作系统/CPU ... -
如何设置google.com
2016-09-02 13:44 875有不少的童鞋说不喜欢HK版的Google,加入ncr (No ... -
ipv6设置操作
2016-09-01 20:47 613IPv6怎么设置 IPv6怎么设置 ... -
yum解锁
2016-08-29 23:42 495yum被锁定时,会提示以下错误: Another app ... -
怎样使用yum来安装mysql
2016-08-29 23:37 458linux下使用yum安装mysql,以及启动、登录和远程访 ... -
linux系统下常用命令
2016-08-24 09:54 433系统 # uname -a ... -
centos7上配置android 开发环境
2016-04-26 13:41 553一、系统配置 公司的电脑,使用了一段时间后 ... -
Linux rpm 命令参数使用详解
2016-04-24 23:49 447RPM是RedHat Package Manager(Red ... -
centos安装JDK
2016-04-24 23:04 522[root@li1260-39~]# rpm -ivh jd ... -
centos7 安装node.js
2016-04-24 13:13 608通过yum管理程序来一键安装即可: yum install ... -
一行命令搞定node.js 版本升级
2016-04-22 14:27 560node有一个模块叫n(这名字可够短的。。。),是专门用来管 ...
相关推荐
同时,STUN服务器的部署也是实现NAT穿透的重要环节,它可以极大地提高P2P网络的连通性和稳定性。 总的来说,NAT穿透技术对于现代互联网服务,如在线游戏、视频通话和分布式文件共享,具有关键作用。通过理解和应用...
在本文中,我们将深入探讨NAT检测工具及其在开发P2P(peer-to-peer,点对点)应用中的重要性。 NAT类型通常分为四种:Full Cone NAT、Restricted Cone NAT、Port Restricted Cone NAT和Symmetric NAT。这些类型的...
NAT(网络地址转换)类型检测工具是一种用于识别网络中NAT设备类型的软件,它对于理解网络连接性、优化P2P(对等网络)通信和解决网络穿透问题至关重要。本项目提供了一套完整的源码,专为研究NAT类型和进行P2P开发...
描述中提到的“实现P2P的NAT穿越的原理的代码加以改进,增加了tell功能”,意味着原有的代码已经实现了基本的NAT穿透,现在进行了优化并添加了新的功能。"Tell功能"可能是指一种通知机制,使得节点能够告知其他节点...
NAT(Network Address ...NAT类型检测对于理解网络通信的限制和优化P2P应用的连通性至关重要,特别是对于需要穿透NAT的服务,如VoIP、在线游戏和远程桌面等。了解NAT类型有助于开发出适应各种网络环境的解决方案。
这些源码可能涵盖了P2P网络架构设计、NAT穿透算法的实现、STUN/TURN服务器的交互逻辑以及ICE协议的封装。通过研究这些源码,开发者可以深入理解P2P穿透打洞的原理,并将其应用于实际的文件传输应用中。 总之,P2P...
`NAT类型测试.exe` 这个文件很可能是用来检测网络连接的NAT类型的工具。通过运行这个程序,用户可以确定自己的网络设置属于哪种NAT类型,这对于解决在线游戏、VoIP通话、P2P文件共享等网络应用的连通性问题至关重要...
这在一定程度上解决了部分NAT穿透问题,但对Symmetric NAT无能为力。 TURN(Traversal Using Relays around NAT)协议则更进一步,当STUN无法成功时,TURN服务器作为中继,接收来自内网设备的数据并转发给目标,...
ICE作为一种新兴的NAT穿透技术,相较于传统的ALGs、STUN和TURN等方案,具有更好的适应性和灵活性。它能够有效地应对复杂的网络环境,尤其是SymmetricNAT这样的难题。随着NGN网络的普及和发展,ICE有望成为未来多媒体...
3. 实践应用:这个服务端程序可能是开发者或研究人员测试P2P网络协议、NAT穿透策略或UDP通信性能的工具。 压缩包子文件的文件名称"UDPServer"暗示这是一个实现了上述功能的UDP服务器程序,可能包含代码、配置文件或...
本资料包“网络游戏-对等网络连通性状态.zip”包含了一份名为“对等网络连通性状态.pdf”的文档,很可能是探讨了P2P网络在网络游戏中的应用以及其连通性状态的相关问题。 首先,我们要理解对等网络的基本原理。在...
4. **NAT穿透**:NAT穿透允许在NAT设备后方的设备通过互联网与其他设备通信,解决因NAT导致的端口转发问题,提高P2P网络的连通性。 5. **UPnP(通用即插即用)**:UPnP是一种网络协议,自动发现和配置网络设备,如...
而H.323 ALG则可以解析和修改H.323呼叫建立过程中的信令消息,保持呼叫的连通性。 ### 结论 尽管NAT在缓解IPv4地址空间短缺方面发挥了重要作用,但它也带来了协议层面的复杂性,尤其是对于那些依赖于特定地址信息...
1. 网络连通性:NAT设备可能会阻止某些依赖于IP地址和端口的协议,如P2P网络和某些VoIP服务。 2. 诊断和追踪:由于IP地址和端口被转换,使得故障定位和安全审计变得更加复杂。 3. 安全隐患:尽管NAT可以提供一定...
- **UPnP/NAT穿透**:自动配置路由器端口映射,改善内网节点的连通性。 - **磁力链接**:替代种子文件,简化文件共享流程。 6. **P2P安全考虑** - **隐私保护**:P2P网络中的用户身份应匿名处理,防止个人信息...
标题中的“udpnat”是一个专为Linux设计的开源项目,其主要目的是提供一个P2P友好的仅UDPv4的用户空间网络地址转换(NAT)解决...尽管目前还在测试阶段,但它的存在为开发者提供了一种新的方法来改善P2P网络的连通性。
本项目“IceConnectivityTest.zip”提供了一个用于测试STUN和TURN服务连通性的程序,这对于理解WebRTC中网络连接的复杂性至关重要。 首先,让我们详细了解一下STUN(Session Traversal Utilities for NAT,NAT穿透...
如ICE(Interactive Connectivity Establishment)、STUN(Session Traversal Utilities for NAT)和TURN(Traversal Using Relays around NAT)等,可以解决NAT穿透和网络中继问题,确保语音通信的连通性。...