我正在解决一个关机问题,但它并不像应该那样优雅,因此我想获取在jvisualvm(或其他工具)中运行的非守护线程列表,以便找出罪魁祸首。
我正在解决一个关机问题,但它并不像应该那样优雅,因此我想获取在jvisualvm(或其他工具)中运行的非守护线程列表,以便找出罪魁祸首。
jstack会转储所有线程,其中有一段文本可以告诉它是否是守护进程。
(jvisualvm在“ThreadDump”中产生相同的输出-请参阅此链接以获取更多有用的文档)
"Reference Handler" daemon prio=10 tid=0x00a98400 nid=0x1ee8 in Object.wait() [0x00b6f000]
java.lang.Thread.State: WAITING (on object monitor)
at java.lang.Object.wait(Native Method)
at java.lang.Object.wait(Object.java:485)
at java.lang.ref.Reference$ReferenceHandler.run(Reference.java:116)
- locked <0x19835fa0> (a java.lang.ref.Reference$Lock)
"VM Thread" prio=10 tid=0x00a95800 nid=0x264 runnable
jstack
,而不是 jstat
。 - ZhekaKozlov