我认为这是由于客户端NAT . 当您的客户端向服务器发送公共IP时,NAT路由器正在其内部连接表中创建一个条目(类似于“192.168.2.85 [777] => 104.40.xxx.250 [6000]) .
因此,当响应从104.40.xxx.250 [6000]返回时,NAT将找到匹配的条目并将响应返回给客户端计算机 . 该条目是它如何知道客户端网络中的哪台机器发送数据包 . 但是,当响应从104.40.xx.250 [46666]返回时,它与其表中的任何条目都不匹配,因此它正在丢弃该数据包 .
这是NAT工作的方式 . 考虑一下你的NAT后面还有另一台机器也在和同一台服务器通话,比如“192.168.2.86 [777] => 104.40.xxx.250 [6000]” . 我想你会发现你的NAT路由器实际上将源端口改为777以外的其他东西 . 否则它如何正确地将响应路由回正确的机器 . 通常对于NAT,如果来自路由器的传入数据包与其表中的条目不匹配(或者您已配置了端口转发规则),则数据包将被丢弃 .
端口转发允许您打开内部计算机以供外界进行一般访问 . 但缺乏这一点,您真的不希望任何随机IP地址/端口对能够将数据报发送到您的客户端计算机 .