如何找到一个在 Linux 上运行的带有 ps -axl 的 Java 线程?
2022-09-01 12:25:08
我有一个正在运行的JVM,有两个线程。是否可以使用ps -axl在我的Linux操作系统上看到这些正在运行的线程?我试图找出操作系统给予我的线程的优先级。有关此其他问题的更多信息,请单击此处。
我有一个正在运行的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
在 Linux 上,Sun/Oracle JVM 使用原生 Linux 线程实现 Java 线程,所以是的,您可以在“ps”输出中看到它们。属于进程的任何线程都是 Java 线程。但是您不会看到线程的名称,因为这些名称特定于Java,操作系统不知道它们。java
Linux线程确实有ID,但它们只是数字,“ps axl”没有显示它们。“ps -eLf”在“LWP”列中确实如此。(“LWP”是“轻量级进程”的缩写,这是线程的另一个名称。在Java中,该方法可能会返回您在“ps -eLf”输出中看到的LWP编号,但我不确定。Thread.getId()