我有一个带有两个线程的JVM。使用ps -axl可以在我的Linux操作系统上看到这些正在运行的线程吗?我试图找出操作系统赋予我的线程什么优先级。
采用
jps -v
查找您的Java进程。样本输出:
3825 RemoteMavenServer -Djava.awt.headless=true -Xmx512m -Dfile.encoding=MacRoman 6172 AppMain -Didea.launcher.port=7533 -Didea.launcher.bin.path=/Applications/IntelliJ IDEA 10.app/bin -Dfile.encoding=UTF-8 6175 Jps -Dapplication.home=/Library/Java/JavaVirtualMachines/1.6.0_31-b04-411.jdk/Contents/Home -Xms8m
然后使用
jstack 6172
(6172是您的进程的ID)以获取jvm中的线程堆栈。从中可以找到线程优先级。样本输出:
..... "main" **prio=5** tid=7ff255800800 nid=0x104bec000 waiting on condition [104beb000] java.lang.Thread.State: TIMED_WAITING (sleeping) at java.lang.Thread.sleep(Native Method) at au.com.byr.Sample.main(Sample.java:11) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) at java.lang.reflect.Method.invoke(Method.java:597) at com.intellij.rt.execution.application.AppMain.main(AppMain.java:120) .....
请享用!
编辑: 如果应用程序在不同于您自己的用户下运行(在生产环境和其他非本地环境中通常会发生这种情况),那么jps / jstack应该通过sudo运行。例子:
sudo jps -v sudo jstack 6172