6

我在远程服务器上部署了一个 Java Web 应用程序。我想从 Eclipse 的本地机器上进行远程调试。它们是相同的版本。代码是否需要由我的本地机器编译才能进行远程调试,还是不需要?我的理解是代码应该由我的本地工具编译。

以下是我认为远程调试的工作原理。如果我错了,请纠正我。

当我将调试器放在 Eclipse 的第 250 行的某个源文件上时,它会在类文件中查找相应的字节码并注意该点(比如说它是类文件中的第 200 行,因为它删除了所有注释和死代码) . 它还将在远程服务器上的类文件的第 200 行放置一种断点。当执行到第 200 行时,调试器将停止,但在 Eclipse 中,为方便开发人员,它将在源代码的第 250 行停止。(它必须进行内部计算以确定源代码中与字节码相对应的确切行。)

4

1 回答 1

2

Eclipse 调试从所谓的代理开始。

运行编译好的.class源代码的 JVM 有一个特性,允许将外部库(用 Java 或 C++ 编写)注入到 JVM 中,就在运行时。这些外部库称为代理,它们能够修改.class已运行文件的内容。这些代理可以访问 JVM 的功能,而这些功能在 JVM 中运行的常规 Java 代码中是无法访问的,它们可以用来做一些有趣的事情,比如注入和修改正在运行的源代码、分析等。(像JRebel这样的工具使用这块功能来实现他们的魔力。)

要将 Agent Lib 传递给 JVM,您可以通过启动参数执行此操作,使用

 agentlib:libname[=options] format.

我们实际上是在将一个名为jdwp的代理库传递给运行 Tomcat 的 JVM。jdwp是 JDWP(Java Debug Wire Protocol)的JVM特定的可选实现,用于定义调试器和正在运行的 JVM 之间的通信。它的实现(如果存在)作为 JVM 的本机库提供,jdwp.so或者jdwp.dll

那么它有什么作用呢?
简单来说,jdwp我们传递的代理基本上是充当运行应用程序的 JVM 实例和调试器(可以位于远程或本地)之间的链接的功能。由于它是一个代理库,它确实具有拦截运行代码的能力,在 JVM 和调试器之间建立桥梁,并具有应用在 JVM 上的调试器的功能。
由于在JVM架构中,调试功能不在 JVM 本身中找到,而是被抽象到外部工具(被恰当地称为调试器)中,这些工具可以驻留在运行正在调试的 JVM 的本地机器上,也可以运行来自外部机器。正是这种解耦、模块化的架构允许我们在远程机器上运行 JVM 并使用 JDWP,让远程调试器能够与之通信

于 2016-06-28T22:54:44.423 回答