jstack

jstack:查看当前所有线程的状态和运行情况
jstack [-option] pid
Options:
-F to force a thread dump. Use when jstack does not respond (process is hung)
-m to print both java and native frames (mixed mode)
-l long listing. Prints additional information about locks

注意事项:
此处线程id为16进制,10进制转16进制 printf “%x” 十进制 16进制转10进制 printf “%d” 0x十进制数

/nemo/jdk/bin/jstack 239637

2021-04-12 21:37:29
Full thread dump Java HotSpot™ 64-Bit Server VM (24.65-b04 mixed mode):

“http-bio-8080-exec-320” daemon prio=10 tid=0x00007faa4809e000 nid=0x8eec waiting on condition [0x00007faa60f95000]
java.lang.Thread.State: WAITING (parking)
at sun.misc.Unsafe.park(Native Method)
- parking to wait for <0x000000074307fa08> (a java.util.concurrent.locks.AbstractQueuedSynchronizer C o n d i t i o n O b j e c t ) a t j a v a . u t i l . c o n c u r r e n t . l o c k s . L o c k S u p p o r t . p a r k ( L o c k S u p p o r t . j a v a : 186 ) a t j a v a . u t i l . c o n c u r r e n t . l o c k s . A b s t r a c t Q u e u e d S y n c h r o n i z e r ConditionObject) at java.util.concurrent.locks.LockSupport.park(LockSupport.java:186) at java.util.concurrent.locks.AbstractQueuedSynchronizer ConditionObject)atjava.util.concurrent.locks.LockSupport.park(LockSupport.java:186)atjava.util.concurrent.locks.AbstractQueuedSynchronizerConditionObject.await(AbstractQueuedSynchronizer.java:2043)
at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:442)
at org.apache.tomcat.util.threads.TaskQueue.take(TaskQueue.java:104)
at org.apache.tomcat.util.threads.TaskQueue.take(TaskQueue.java:32)
at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1068)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
at java.util.concurrent.ThreadPoolExecutor W o r k e r . r u n ( T h r e a d P o o l E x e c u t o r . j a v a : 615 ) a t o r g . a p a c h e . t o m c a t . u t i l . t h r e a d s . T a s k T h r e a d Worker.run(ThreadPoolExecutor.java:615) at org.apache.tomcat.util.threads.TaskThread Worker.run(ThreadPoolExecutor.java:615)atorg.apache.tomcat.util.threads.TaskThreadWrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:745)

“http-bio-8080-exec-319” daemon prio=10 tid=0x00007faa4809c800 nid=0x8eeb waiting on condition [0x00007faa61ca2000]
java.lang.Thread.State: WAITING (parking)
at sun.misc.Unsafe.park(Native Method)
- parking to wait for <0x000000074307fa08> (a java.util.concurrent.locks.AbstractQueuedSynchronizer C o n d i t i o n O b j e c t ) a t j a v a . u t i l . c o n c u r r e n t . l o c k s . L o c k S u p p o r t . p a r k ( L o c k S u p p o r t . j a v a : 186 ) a t j a v a . u t i l . c o n c u r r e n t . l o c k s . A b s t r a c t Q u e u e d S y n c h r o n i z e r ConditionObject) at java.util.concurrent.locks.LockSupport.park(LockSupport.java:186) at java.util.concurrent.locks.AbstractQueuedSynchronizer ConditionObject)atjava.util.concurrent.locks.LockSupport.park(LockSupport.java:186)atjava.util.concurrent.locks.AbstractQueuedSynchronizerConditionObject.await(AbstractQueuedSynchronizer.java:2043)
at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:442)
at org.apache.tomcat.util.threads.TaskQueue.take(TaskQueue.java:104)
at org.apache.tomcat.util.threads.TaskQueue.take(TaskQueue.java:32)
at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1068)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
at java.util.concurrent.ThreadPoolExecutor W o r k e r . r u n ( T h r e a d P o o l E x e c u t o r . j a v a : 615 ) a t o r g . a p a c h e . t o m c a t . u t i l . t h r e a d s . T a s k T h r e a d Worker.run(ThreadPoolExecutor.java:615) at org.apache.tomcat.util.threads.TaskThread Worker.run(ThreadPoolExecutor.java:615)atorg.apache.tomcat.util.threads.TaskThreadWrappingRunnable.run(TaskThread.java:61)

/nemo/jdk/bin/jstack -m 239637

Attaching to process ID 239637, please wait…
Debugger attached successfully.
Server compiler detected.
JVM version is 24.65-b04
Deadlock Detection:

No deadlocks found.

----------------- 239638 -----------------
0x00000039ef80b68c __pthread_cond_wait + 0xcc
0x00007faa754beaaf _ZN7Monitor5IWaitEP6Threadl + 0xef
0x00007faa754bf23e _ZN7Monitor4waitEblb + 0x22e
0x00007faa752339e3 _ZN13GCTaskManager8get_taskEj + 0x43
0x00007faa752350a8 _ZN12GCTaskThread3runEv + 0x188
0x00007faa754fd988 _ZL10java_startP6Thread + 0x108
----------------- 239639 -----------------
0x00000039ef80b68c __pthread_cond_wait + 0xcc
0x00007faa754beaaf _ZN7Monitor5IWaitEP6Threadl + 0xef
0x00007faa754bf23e _ZN7Monitor4waitEblb + 0x22e
0x00007faa752339e3 _ZN13GCTaskManager8get_taskEj + 0x43
0x00007faa752350a8 _ZN12GCTaskThread3runEv + 0x188
0x00007faa754fd988 _ZL10java_startP6Thread + 0x108
----------------- 239640 -----------------
0x00000039ef80b68c __pthread_cond_wait + 0xcc
0x00007faa754beaaf _ZN7Monitor5IWaitEP6Threadl + 0xef
0x00007faa754bf23e _ZN7Monitor4waitEblb + 0x22e
0x00007faa752339e3 _ZN13GCTaskManager8get_taskEj + 0x43
0x00007faa752350a8 _ZN12GCTaskThread3runEv + 0x188
0x00007faa754fd988 _ZL10java_startP6Thread + 0x108
----------------- 239641 -----------------

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Linux jstack是一个命令行工具,用于生成Java线程转储。它可以帮助开发人员分析Java应用程序中的线程问题,如死锁、死循环等。jstack命令可以显示Java虚拟机中所有线程的状态,包括线程ID、线程名称、线程状态、线程堆栈等信息。开发人员可以使用这些信息来诊断线程问题并进行调试。 ### 回答2: linux jstack是一个用于诊断和调试Java应用程序的实用程序。它提供了一种查看Java应用程序运行时线程状态的方式,可以帮助开发人员分析线程堆栈,定位和解决应用程序中的性能问题和死锁等并发问题。 使用jstack命令可以获取Java应用程序的线程信息和线程堆栈信息。当应用程序出现性能问题时,可以使用jstack命令来查看应用程序的线程状态,以确定是否存在线程阻塞、死锁或竞争条件等问题。 使用jstack命令非常简单,只需要在终端中输入"jstack"加上Java应用程序的进程ID即可。命令执行后,会输出每个线程的ID、状态、所属的进程ID、线程堆栈信息等。通过分析线程堆栈信息,可以找到应用程序中可能存在的性能瓶颈和并发问题。 jstack命令还可以与其他性能诊断工具和分析工具配合使用。例如,可以将jstack输出的线程堆栈信息与VisualVM等工具进行对比分析,以进一步深入了解应用程序的性能瓶颈和并发问题。 总之,linux jstack是一个非常有用的工具,可以帮助开发人员诊断和调试Java应用程序。通过使用jstack命令,开发人员可以获得关于线程状态和线程堆栈信息的详细分析,以解决应用程序的性能问题和并发问题。 ### 回答3: linux jstack是一个在Linux系统上运行的命令行工具,用于生成Java线程的堆栈跟踪信息。 在Linux系统上,Java应用程序通常由Java虚拟机(JVM)执行。当JVM执行时,它会创建多个线程来并发执行不同的任务。这些线程之间可能会相互依赖,或者可能会出现死锁或其他线程相关的问题。 当出现线程相关的问题时,我们可以使用linux jstack命令来获取Java线程的堆栈跟踪信息。通过查看线程的堆栈跟踪信息,我们可以获得线程在执行过程中的详细信息,例如线程的调用栈、锁的所有权信息等。 要使用linux jstack命令,我们首先需要找到正在执行的Java应用程序的进程ID。然后,在终端中执行以下命令: jstack <PID> 其中<PID>是Java应用程序的进程ID。执行该命令后,linux jstack将生成一个包含所有Java线程的堆栈跟踪信息的输出文件。 通过分析这个输出文件,我们可以获得关于Java线程状态、锁信息、线程调用栈等详细信息。例如,我们可以查看哪个线程持有了锁、哪些线程正在等待锁等。 总而言之,linux jstack是一个用于生成Java线程堆栈跟踪信息的命令行工具。它是一个非常有用的工具,可以帮助我们在诊断和解决Java应用程序中的线程相关问题时提供有价值的信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值