尝试使用 jdb 附加到进程时出现的问题

Dan*_*Dan 4 java debugging jdb

我需要将 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
Run Code Online (Sandbox Code Playgroud)

控制台中显示以下消息:

Listening for transport dt_socket at address: 8000
Run Code Online (Sandbox Code Playgroud)

应用程序开始正常运行。

然后,从远程主机,我执行以下命令:

> jdb -connect com.sun.jdi.SocketAttach:hostname=<remote_host>,port=8000
Run Code Online (Sandbox Code Playgroud)

它失败了,输出是:

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.
Run Code Online (Sandbox Code Playgroud)

我检查过的

为了检查端口是否实际打开并且我可以从远程主机连接到它,我执行了以下操作:

让我们调用正在执行 java 应用程序的主机。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>
Run Code Online (Sandbox Code Playgroud)

在hostA中,检查我是否可以连接到端口8000(换句话说,尝试从本地主机连接)

> nc -vz localhost 8000
nc: connect to localhost port 8000 (tcp) failed: Connection refused
Connection to localhost 8000 port [tcp/irdmi] succeeded!
Run Code Online (Sandbox Code Playgroud)

使用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.
Run Code Online (Sandbox Code Playgroud)

Java 应用程序。telnet 连接关闭时显示以下消息:

Debugger failed to attach: timeout during handshak
Run Code Online (Sandbox Code Playgroud)

从 hostB,检查我是否可以连接到 hostA,端口 8000

> nc -vz hostA 8000
nc: connect to hostA port 8000 (tcp) failed: Connection refused
Run Code Online (Sandbox Code Playgroud)

使用远程登录:

> telnet hostA 8000
Trying 172.17.10.127...
telnet: connect to address 172.17.10.127: Connection refused
Run Code Online (Sandbox Code Playgroud)

因此,我无法通过端口 8000从hostA到连接hostB,尽管 JVM 正在侦听端口 8000,在hostA.

由于上述失败,我检查了防火墙是否导致连接被拒绝。我已经使用 nc 命令完成了它:

hostA

# First kill the java app (otherwise the port is busy), then:
> nc -l 8000
Run Code Online (Sandbox Code Playgroud)

hostB

> nc -vz <hostA> 8000
Connection to hostA 8000 port [tcp/irdmi] succeeded!
Run Code Online (Sandbox Code Playgroud)

据我了解,以上意味着没有防火墙(或等效物)阻止端口。

编辑

当然,我曾尝试这样做,jdb -attach但即使从hostA.

Chr*_*ker 5

我没有足够的积分来评论。所以我把这个作为答案。真的不是。但:

-Xdebug -agentlib:jdwp=transport=dt_socket,address=127.0.0.1:8000,serv=y,suspend=n

难道不应该是:

-Xdebug -agentlib:JDWP = =运输dt_socket,地址127.0.0.1 =:8000,SERV ER = Y,暂停= N

??

[编辑] 您可能已经考虑到了这一点 - 而且,如果您正在收听 127.0.0.1,那么您不会从远程计算机进行连接也是理所当然的。毫无疑问,您使用的是实际地址,只是没有将其包含在此处...


Dan*_*Dan 3

我发现连接问题了。在我用来启动java应用程序的命令中,我更改了地址参数,如下所示:

前:

-Xdebug -agentlib:jdwp=transport=dt_socket,address=127.0.0.1:8000,server=y,suspend=n
Run Code Online (Sandbox Code Playgroud)

之后(参见address):

-Xdebug -agentlib:jdwp=transport=dt_socket,address=8000,server=y,suspend=n
Run Code Online (Sandbox Code Playgroud)