首页 文章

UDP打孔过期[关闭]

提问于
浏览
1

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 回答

  • 3

    我怀疑这种行为是特定于你的NAT . 听起来端口映射逻辑存在问题 . 您可能会在网络上放置一个不同的NAT框,并看到不同的行为 .

    我的建议是始终为每个对等会话使用不同的本地端口和套接字 . 因此,假设您在第一个会话中使用端口2000与服务器和对等方通信,那么下一个会话应该使用完全不同的本地端口 . 然后,NAT与前一个端口出现的任何问题都不会影响这个新套接字 .

    通常,如果要在一对主机之间保持UDP通道打开,则每45秒至少应有一个数据包流 .

相关问题