【发布时间】:2017-03-13 14:59:40
【问题描述】:
我需要将 jdb 调试会话附加到正在远程主机中执行的 java 应用程序,但我无法执行此操作。我在 linux 上工作,使用 openjdk 1.8.0_65, 64-Bit Server VM。
我尝试过的
为了启用端口监听,我运行了 java 应用程序,在命令行中添加了以下参数:
-Xdebug -agentlib:jdwp=transport=dt_socket,address=127.0.0.1:8000,server=y,suspend=n
控制台中显示以下消息:
Listening for transport dt_socket at address: 8000
应用程序开始正常运行。
然后,我从远程主机执行以下命令:
> jdb -connect com.sun.jdi.SocketAttach:hostname=<remote_host>,port=8000
失败了,输出是:
java.net.ConnectException: Conexión rehusada
at java.net.PlainSocketImpl.socketConnect(Native Method)
at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350)
[...]
Fatal error:
Unable to attach to target VM.
我检查了什么
为了检查端口是否真的打开并且我可以从远程主机连接到它,我执行了以下操作:
让我们调用正在执行 java 应用程序的主机。 hostA,我想附上jdbhostB,然后:
检查 hostA 中的 8000 端口是否确实有一个套接字正在侦听
> netstat -tualpn | grep :8000
tcp 0 0 127.0.0.1:8000 0.0.0.0:* LISTEN 1399/<app_name>
在hostA中,检查我是否可以连接到8000端口(也就是说,尝试从本地主机连接)
> nc -vz localhost 8000
nc: connect to localhost port 8000 (tcp) failed: Connection refused
Connection to localhost 8000 port [tcp/irdmi] succeeded!
使用telnet,它似乎可以连接,但连接一建立就关闭,可能是因为JVM期待某种请求?
> telnet localhost 8000
Trying ::1...
telnet: connect to address ::1: Connection refused
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
Connection closed by foreign host.
Java 应用程序。关闭 telnet 连接时显示以下消息:
Debugger failed to attach: timeout during handshak
从 hostB,检查我是否可以连接到 hostA,端口 8000
> nc -vz hostA 8000
nc: connect to hostA port 8000 (tcp) failed: Connection refused
使用远程登录:
> telnet hostA 8000
Trying 172.17.10.127...
telnet: connect to address 172.17.10.127: Connection refused
因此,我无法通过端口 8000 从 hostA 连接到 hostB,尽管 JVM 正在 hostA 中的端口 8000 上进行侦听。
由于上述失败,我检查了防火墙是否导致连接被拒绝。我已经使用 nc 命令完成了:
在hostA:
# First kill the java app (otherwise the port is busy), then:
> nc -l 8000
在hostB:
> nc -vz <hostA> 8000
Connection to hostA 8000 port [tcp/irdmi] succeeded!
据我了解,以上表示没有防火墙(或等效的)阻止该端口。
编辑
当然,我尝试过 jdb -attach,但即使从 hostA 开始也失败了。
【问题讨论】:
-
您是否尝试过从同一台计算机连接到它?
-
是的,就是步骤“在hostA中,检查我是否可以连接到8000端口”
-
我明白了。我对 nc 命令不太熟悉;在hostA中,
nc -vz localhost 8000怎么会失败又成功? -
我不知道。我搜索了
irdmi是什么,但我没有找到任何对我的问题有用的东西。 -
我在
hostA和hostB添加了一个新的使用telnet 的检查