以编程方式进行线程转储/ JDI(Java调试器接口)

时间:2008-10-27 10:48:35

标签: java debugging thread-dump

我喜欢以编程方式生成线程转储。我了解到基本上有两种方法可以做到:

  1. 使用“Java虚拟机工具接口”JVM-TI
  2. 使用更高抽象的“Java调试器接口”JDI
  3. 对于JVM-TI,我能够找到一些有用的信息,但我必须编写一个JNI-DLL,至少暂时我想避免。使用JDI,我可以使用Java,似乎我可以在应用程序中使用它。但我无法找到某种教程或HOWTO。我能找到的唯一文档是Java-Docs http://java.sun.com/j2se/1.5.0/docs/guide/jpda/jdi/,它不是很有帮助,因为它没有告诉我如何使用这些类。

    那么,有没有人知道我能阅读的好教程/书?

    感谢您的帮助!

4 个答案:

答案 0 :(得分:21)

还有第三种方法:Thread.getAllStackTraces()

http://java.sun.com/javase/6/docs/api/java/lang/Thread.html#getAllStackTraces()

这比调试器界面容易得多......

答案 1 :(得分:8)

您可以获得所需的所有线程信息,包括来自http://java.sun.com/javase/6/docs/api/java/lang/management/ThreadMXBean.html

的死锁

答案 2 :(得分:3)

Thread.getAllStackTraces()仅转储所有线程的执行跟踪,但不提供由特定线程或特定线程等待的锁获取的对象锁的信息。基本上,我们无法用这个来解决僵局。

答案 3 :(得分:1)

您是否考虑过远程替代方案?即VisualVM

thead dump with visualVM

jps and jstack也是JDK 5中包含的有用工具,提供了一种快速命令行方法,用于获取所有当前线程的堆栈跟踪。

本文建议JDI也用作remote tool

所以我不确定你是否可以在自己的程序中触发线程转储,而是找到一种在Unix平台上向自己发送SIGQUIT信号(kill -3)的方法,或者在Unix上按Ctrl- \键或Windows平台上的Ctrl-Break。

另外,JDI wasn't intended to be used to debug the same process in which the JDI client is running。我刚刚链接的这个线程仍然是我在同一个程序中实际使用JDI的最接近的。