[更新:在top
中,在我按下Shift + H后,它显示了线程而不是进程,然后它将Java线程显示为R并使用100%CPU时间,这是我在发布之前的预期问题。]
由于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)
答案 0 :(得分:2)
JVM有许多线程正在运行以进行“内务管理”,如垃圾收集等。大多数情况下,它们处于睡眠状态。
答案 1 :(得分:1)
然后,运行top显示进程状态为S,并且它使用100%CPU时间。
我认为问题很可能与top
确定流程状态的方式有关。在OS级别,具有运行/等待/睡眠状态的是单个线程。我的猜测是top
命令的启发式算法用于确定该过程的名义运行/等待/睡眠状态是误导。
(jstack
的输出......和常识......支持这一理论。)
答案 2 :(得分:0)
这个线程忙于使用CPU,它没有睡觉。
"main" prio=10 tid=0x00007fd7ec007800 nid=0x669b runnable [0x00007fd7f5754000]
java.lang.Thread.State: RUNNABLE
at Test.main(Test.java:5)
这表明顶部的信息不正确。
答案 3 :(得分:0)
有很多关于“为什么你有多个线程,以及他们用Java做什么”的解释,但没有那么多。 top
命令本身非常简单,因为它只是通过收集信息所需的系统调用 - 例如getrusage
用于获取CPU使用率。
通常,正如所解释的那样,top
会立即查看整个过程,所有线程。您可以在top
中按“H”,它将显示单个线程而不是整个过程,然后您将能够看到所有Java线程[如果您的屏幕足够高],主要的是使用无限循环中的所有CPU,其他线程主要是什么都不做。