我需要将jdb调试会话附加到正在远程主机中执行的java应用程序,但我无法执行此操作。我正在开发linux,使用openjdk 1.8.0_65,64位服务器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 app的主机。 hostA
,以及我要附加jdb
hostB
的那个,然后:
检查在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:
> 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
执行此操作。
答案 0 :(得分:2)
我没有足够的评论意见。所以我将此作为答案。它真的不是。但是:
-Xdebug -agentlib:jdwp = transport = dt_socket,address = 127.0.0.1:8000,serv = y,suspend = n
不应该是:
-Xdebug -agentlib:jdwp = transport = dt_socket,address = 127.0.0.1:8000,serv er = y,suspend = n
...
[编辑]你可能已经考虑到这一点了 - 但是,如果你正在收听127.0.0.1,那么你就不会从远程计算机连接了。毫无疑问,你使用的是实际地址,而且这里没有包含它......
答案 1 :(得分:0)
我发现了连接问题。在我用来启动java应用程序的命令中,我更改了地址参数,如下所示:
在:
-Xdebug -agentlib:jdwp=transport=dt_socket,address=127.0.0.1:8000,server=y,suspend=n
之后(见address
):
-Xdebug -agentlib:jdwp=transport=dt_socket,address=8000,server=y,suspend=n