UPDATE
It turned out that the problem is unrelated to NAT and UDP hole punching. So I have created a new Q.
我使用以下方法实现了UDP打孔:
已知端口上的已知服务器(无NAT)正在处理传入的UDP .
NAT后面的客户端向服务器发送数据报,之后服务器通过向该客户端发送对等体的地址来响应 .
客户端现在开始使用同一套接字上的UDP与对等方进行通信(但当然是使用不同的地址) .
如果一段时间后,客户端停止与对等方的通信,并再次向服务器发送另一个数据报,则此数据报不会到达(除非我通过从服务器向客户端发送keepalive数据报来保持通道打开 . )
我的问题:如何从服务器< - >客户端之间的数据报切换到对等< - >客户端之间的数据报,但是一旦我切换回来并且客户端再次发送到服务器,它们就不会到达?
1 回答
我怀疑这种行为是特定于你的NAT . 听起来端口映射逻辑存在问题 . 您可能会在网络上放置一个不同的NAT框,并看到不同的行为 .
我的建议是始终为每个对等会话使用不同的本地端口和套接字 . 因此,假设您在第一个会话中使用端口2000与服务器和对等方通信,那么下一个会话应该使用完全不同的本地端口 . 然后,NAT与前一个端口出现的任何问题都不会影响这个新套接字 .
通常,如果要在一对主机之间保持UDP通道打开,则每45秒至少应有一个数据包流 .