我一直在尝试连接到我自己的 Java TCP 应用程序,该应用程序在具有静态公共 IP 的租用服务器上运行。
有效的场景:
- 服务器运行主机应用程序,来自https://check-host.net/的服务器连接到它。
- [我的] PC 运行主机和客户端应用程序并连接它们。
不起作用的场景:
- 服务器运行主机应用程序和 [my] PC 尝试连接(w\ 客户端应用程序、PowerShell Test-NetConnection、CMD telnet)
- [我的] PC 运行主机应用程序,服务器尝试连接客户端应用程序。
额外细节:
- 服务器和我的电脑可以互相ping通。
- 我试过禁用windows防火墙,但无济于事。
- 我的电脑通过调制解调器连接到互联网(我不熟悉调制解调器的限制)
- 当尝试在我的 PC 上启动主机应用程序并将其当前公共 IP 指定为绑定地址时,Java 抛出 IOExeption:“java.net.BindException:无法分配请求的地址:绑定”。(租用的服务器执行相同的程序没有问题)
[不再是真的]我会让服务器继续运行,对于那些想要尝试连接的人:IP = **.***.***.** 端口 = 25 协议 = TCP(如果成功连接来自有人在家,那么我至少知道问题是本地的)
我完全不知所措,希望我能提供足够的信息来暗示出了什么问题。我感谢所有关于可能出现问题的反馈。
提前致谢。
所以,你的问题实际上主要是这样的:
这意味着程序没有正确启动。您将无法从远程或本地设备连接到它。
为什么它无法在您的 PC 上运行有两种可能性。首先,绑定到 1024 以下的端口是大多数操作系统上的特权操作。您需要管理员权限才能执行此操作。您正在尝试绑定到端口 25。
然后,“明显”的问题:您的 PC 可能实际上没有您的公共 IP 地址。如今,直接连接到互联网(无需路由器)极为罕见。相反,路由器具有公共 IP 地址。你的“调制解调器”可能实际上是一个路由器。或者,您可能落后于运营商级 NAT (CGNAT)。这将使您无法接受传入的连接。
在您的 PC 上,您必须使用其本地 IP 地址(类似于192.168.123.123)。在您的路由器上,您必须设置端口转发。
dave_thompson_085 还专门提出了一个关于端口 25 (SMTP) 的有效端口:由于此端口上流量的垃圾邮件性质,许多 ISP 将其阻止,即使它们允许传入连接。
有了评论和@DanielB 给我的信息,我能够解决这个问题。
现在,应用程序双向连接良好。虽然我也了解到我要在我的 PC 上使用我的本地 IP 进行主机,但是从服务器连接到 PC 的公共 IP。
感谢所有的投入!如果没有它,我将无法如此快速地解决问题。