[更新:在top,我按shift + H,它显示线程而不是进程,然后显示Java线程为R,并使用100%CPU时间,这是我发布此问题之前所期望的。]Linux top命令如何确定Java进程的状态?
由于Java进程有多个线程,每个线程可能处于不同的状态,那么Linux top命令如何确定Java进程状态?
如果我运行下面的代码,
public class Test{
public static void main(String[] args){
while (true){
int n = (int)(Math.random() * 1000);
}
}
}
然后,运行top表明,该工艺状态是S,而且它使用100%的CPU时间。
此外,运行strace显示,只显示:
futex(0x7f6ba759c9d0, FUTEX_WAIT, 26060, NULL
但是,运行jstack显示,主线程RUNNABLE:
"main" prio=10 tid=0x00007fd7ec007800 nid=0x669b runnable [0x00007fd7f5754000]
java.lang.Thread.State: RUNNABLE
at Test.main(Test.java:5)
jstack也表明,只有两个WAITING状态下的线程:
"Finalizer" daemon prio=10 tid=0x00007fd7ec080000 nid=0x66a6 in Object.wait() [0x00007fd7f0252000]
java.lang.Thread.State: WAITING (on object monitor)
at java.lang.Object.wait(Native Method)
- waiting on <0x00000007ad001310> (a java.lang.ref.ReferenceQueue$Lock)
at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:133)
- locked <0x00000007ad001310> (a java.lang.ref.ReferenceQueue$Lock)
at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:149)
at java.lang.ref.Finalizer$FinalizerThread.run(Finalizer.java:177)
"Reference Handler" daemon prio=10 tid=0x00007fd7ec07e000 nid=0x66a5 in Object.wait() [0x00007fd7f0353000]
java.lang.Thread.State: WAITING (on object monitor)
at java.lang.Object.wait(Native Method)
- waiting on <0x00000007ad0011e8> (a java.lang.ref.Reference$Lock)
at java.lang.Object.wait(Object.java:502)
at java.lang.ref.Reference$ReferenceHandler.run(Reference.java:133)
- locked <0x00000007ad0011e8> (a java.lang.ref.Reference$Lock)
2012-12-30
zzhang
+1
top命令按进程聚合信息(pid)。通过用'-o th'命令查看命令,可以看到进程总共有多少个线程。使用统计信息从进程的活动线程汇总。 –