尝试使用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

以下消息显示在控制台中:

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,以及我要附加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

所以,尽管JVM在端口8000中,hostA中的JVM在侦听。

,我无法连接到hostAhostB

由于上述失败,我检查了防火墙是否导致连接被拒绝。我已经使用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进行操作。

我没有足够的积分来评论。因此,我将其包括在内。真的不是。但是:

-xdebug -agentlib:jdwp = transport = dt_socket,地址= 127.0.0.1:8000,serv = y,sissend = n

不应该是:

-xdebug -agentlib:jdwp = transport = dt_socket,地址= 127.0.0.1:8000,serv er = y,susteend = n

??

[编辑]您可能已经在考虑这一点 - 而且,如果您在127.0.0.1上收听,那么它就可以理解您不会从远程计算机连接。毫无疑问,您正在使用实际地址,只是在这里不包括它...

我找到了连接问题。在我用来启动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

相关内容

  • 没有找到相关文章

最新更新