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

标签 java debugging jdb

我需要将 jdb 调试 session 附加到正在远程主机上执行的 java 应用程序,但我无法执行此操作。我在 Linux 上工作,使用 openjdk 1.8.0_65、64 位服务器虚拟机。

我尝试过的

为了启用端口监听,我运行了 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中是否真的有socket监听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 正在监听端口 8000,在 hostA.

由于上述失败,我检查了是否防火墙导致连接被拒绝。我已经通过使用 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,address=127.0.0.1:8000,serv=y,suspend=n

难道不应该是:

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

??

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

关于java - 尝试使用 jdb 附加到进程时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42766798/

相关文章:

java - 如何使用java从Mongodb集合中检索数组列表的元素?

java - 从 Firebase 数据库检索交叉对象子级

java - eclipse 调试器 - 在特定位置引发异常时的断点

jdb - fatal error : unable to launch target VM

android - 带有 Android 应用程序的 jdb - 无法打开源文件

java - 使用内部类的 JDBI

javascript - Chart.JS 自定义 - 如何调试?

c - 为什么这不打印到标准输出 (stdout)?

java - vagrant debug 无法从主机访问调试端口 8000

java - 看不懂Priority Queue流程