jstack命令可以用来查看运行的Java进程下,多线程的运行情况,语句如“[root@admin ~]# jstack 43616

Full thread dump Java HotSpot(TM) 64-Bit Server...”。

Java jstack 命令详解

Java 中 jstack 命令可以用来查看运行的 Java 进程下,多线程的运行情况,我们用一个死锁的例子来看:

比如下面这段死锁的代码:public class DeadLock {

private static Object objA = new Object();

private static Object objB = new Object();

public static void main(String[] args) {

Thread thread1 = new Thread(new Thread1());

Thread thread2 = new Thread(new Thread2());

thread1.start();

thread2.start();

}

private static class Thread1 implements Runnable{

@Override

public void run() {

synchronized (objA) {

System.out.println("线程1得到A对象的锁");

try {

Thread.sleep(3000);

} catch (InterruptedException e) {

e.printStackTrace();

}

synchronized (objB) {

System.out.println("线程1得到B对象的锁");

}

}

}

}

private static class Thread2 implements Runnable{

@Override

public void run() {

synchronized (objB) {

System.out.println("线程2得到B对象的锁");

try {

Thread.sleep(3000);

} catch (InterruptedException e) {

e.printStackTrace();

}

synchronized (objA) {

System.out.println("线程2得到A对象的锁");

}

}

}

}

}

当然,运行结果只能看到两个线程只拿到了一个锁,在一直等待对方的锁。线程1得到A对象的锁

线程2得到B对象的锁

我们可以使用 jps 来查看对应的 PID ,然后使用 jstack 来查看其线程情况:[root@admin ~]# jps

42576 Jps

43616 DeadLock[root@admin ~]# jstack 43616

Full thread dump Java HotSpot(TM) 64-Bit Server VM (24.45-b08 mixed mode):

"DestroyJavaVM" prio=6 tid=0x00000000047c1000 nid=0x9878 waiting on condition [0x0000000000000000]

java.lang.Thread.State: RUNNABLE

"Thread-1" prio=6 tid=0x0000000010aa3000 nid=0xafa0 waiting for monitor entry [0x000000001105f000]

java.lang.Thread.State: BLOCKED (on object monitor)

at com.zaimeibian.Test$Thread2.run(Test.java:46)

- waiting to lock <0x00000007c099cc20> (a java.lang.Object)

- locked <0x00000007c099cc30> (a java.lang.Object)

at java.lang.Thread.run(Thread.java:744)

"Thread-0" prio=6 tid=0x0000000010aa2800 nid=0xae74 waiting for monitor entry [0x0000000010f5f000]

java.lang.Thread.State: BLOCKED (on object monitor)

at com.zaimeibian.Test$Thread1.run(Test.java:27)

- waiting to lock <0x00000007c099cc30> (a java.lang.Object)

- locked <0x00000007c099cc20> (a java.lang.Object)

at java.lang.Thread.run(Thread.java:744)

"Service Thread" daemon prio=6 tid=0x000000000f10a000 nid=0x9a8c runnable [0x0000000000000000]

java.lang.Thread.State: RUNNABLE

"C2 CompilerThread1" daemon prio=10 tid=0x000000000f109800 nid=0xaf28 waiting on condition [0x0000000000000000]

java.lang.Thread.State: RUNNABLE

"C2 CompilerThread0" daemon prio=10 tid=0x000000000f105800 nid=0x85dc waiting on condition [0x0000000000000000]

java.lang.Thread.State: RUNNABLE

"Attach Listener" daemon prio=10 tid=0x000000000f104800 nid=0xac04 waiting on condition [0x0000000000000000]

java.lang.Thread.State: RUNNABLE

"Signal Dispatcher" daemon prio=10 tid=0x000000000f102000 nid=0xa678 runnable [0x0000000000000000]

java.lang.Thread.State: RUNNABLE

"Finalizer" daemon prio=8 tid=0x000000000f0bd000 nid=0xaed8 in Object.wait() [0x000000001045f000]

java.lang.Thread.State: WAITING (on object monitor)

at java.lang.Object.wait(Native Method)

- waiting on <0x00000007c0905568> (a java.lang.ref.ReferenceQueue$Lock)

at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:135)

- locked <0x00000007c0905568> (a java.lang.ref.ReferenceQueue$Lock)

at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:151)

at java.lang.ref.Finalizer$FinalizerThread.run(Finalizer.java:189)

"Reference Handler" daemon prio=10 tid=0x000000000f0b2000 nid=0xaedc in Object.wait() [0x000000001035f000]

java.lang.Thread.State: WAITING (on object monitor)

at java.lang.Object.wait(Native Method)

- waiting on <0x00000007c09050f0> (a java.lang.ref.Reference$Lock)

at java.lang.Object.wait(Object.java:503)

at java.lang.ref.Reference$ReferenceHandler.run(Reference.java:133)

- locked <0x00000007c09050f0> (a java.lang.ref.Reference$Lock)

"VM Thread" prio=10 tid=0x000000000f0b0000 nid=0xaef0 runnable

"GC task thread#0 (ParallelGC)" prio=6 tid=0x00000000047d6000 nid=0xacb0 runnable

"GC task thread#1 (ParallelGC)" prio=6 tid=0x00000000047d8000 nid=0xaee0 runnable

"GC task thread#2 (ParallelGC)" prio=6 tid=0x00000000047d9800 nid=0xaed4 runnable

"GC task thread#3 (ParallelGC)" prio=6 tid=0x00000000047db000 nid=0xac54 runnable

"VM Periodic Task Thread" prio=10 tid=0x000000000f132000 nid=0xaff0 waiting on condition

JNI global references: 105

Found one Java-level deadlock:

=============================

"Thread-1":

waiting to lock monitor 0x000000000f0ba488 (object 0x00000007c099cc20, a java.lang.Object),

which is held by "Thread-0"

"Thread-0":

waiting to lock monitor 0x000000000f0bcf28 (object 0x00000007c099cc30, a java.lang.Object),

which is held by "Thread-1"

Java stack information for the threads listed above:

===================================================

"Thread-1":

at com.zaimeibian.Test$Thread2.run(Test.java:46)

- waiting to lock <0x00000007c099cc20> (a java.lang.Object)

- locked <0x00000007c099cc30> (a java.lang.Object)

at java.lang.Thread.run(Thread.java:744)

"Thread-0":

at com.zaimeibian.Test$Thread1.run(Test.java:27)

- waiting to lock <0x00000007c099cc30> (a java.lang.Object)

- locked <0x00000007c099cc20> (a java.lang.Object)

at java.lang.Thread.run(Thread.java:744)

Found 1 deadlock.

我们可以看到 jstack 打印出了线程的状态,而且发现一个死锁。

另外,线程状态有以下几种:

- RUNNABLE 线程运行中或 I/O 等待

- BLOCKED 线程在等待 monitor 锁( synchronized 关键字)

- TIMED_WAITING 线程在等待唤醒,但设置了时限

- WAITING 线程在无限等待唤醒

java jstack使用_jstack命令详解相关推荐

  1. java jstack使用_jstack命令的使用

    文章来源:https://blog.csdn.net/wufaliang003/article/details/80414267 jstack是java虚拟机自带的一种堆栈跟踪工具. jstack用于 ...

  2. java $1参数_jmap命令详解----查看JVM内存使用详情

    linux获取java进程PID: https://www.cnblogs.com/sxdcgaq8080/p/10734752.html 如果命令使用过程中报错,可能解决你问题的方案: https: ...

  3. java jstat m ccs_jstat命令详解

    jstat命令使用 jstat命令可以查看堆内存各部分的使用量,以及加载类的数量.命令的格式如下: jstat [-命令选项] [vmid] [间隔时间/毫秒] [查询次数] 注意:使用的jdk版本是 ...

  4. java : java -jar,java -cp,jar cvf 命令详解

    jar cvf ./main.jar ./ 将当前目录下的所有文件打成jar包,jar包名为main.jar(放在工作目录下) java -jar  *.jar param1 param2 运行jar ...

  5. linux中jstack命令详解,Linux jstack命令详解

    jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息. 如果是在64位机器上,需要指定选项"-J-d64",Windows的jstack ...

  6. 把java文件打包成.jar (jar命令详解)

    把java文件打包成.jar (jar命令详解) 先打开命令提示符(win2000或在运行框里执行cmd命令,win98为DOS提示符),输入jar Chelp,然后回车(如果你盘上已经有了jdk1. ...

  7. java 远程shell脚本_java通过ssh连接服务器执行shell命令详解及实例

    java通过ssh连接服务器执行shell命令详解 java通过ssh连接服务器执行shell命令:JSch 是SSH2的一个纯Java实现.它允许你连接到一个sshd 服务器,使用端口转发,X11转 ...

  8. java文件打包jar文件_把java文件打包成.jar (jar命令详解)

    把java文件打包成.jar (jar命令详解) 先打开命令提示符(win2000或在运行框里执行cmd命令,win98为DOS提示符),输入jar Chelp,然后回车(如果你盘上已经有了jdk1. ...

  9. java开发中常用的Git命令详解

    java开发中常用的Git命令详解(IDEA内如何操作) 一:写这篇文章的目的是什么? 二:使用场景在哪里? 1:当我们要使用idea去git仓库拉代码时,首先我们的idea得配置git工具 2:项目 ...

最新文章

  1. 数据科学家需要知道的5种图算法
  2. smartform 中currency 字段的小数点问题
  3. c primer plus 第6版 中文版pdf_一种2-C聚酯修补填充剂
  4. Kali 装机之后的各种操作
  5. CF1110E-Magic Stones【结论题,差分】
  6. GWT和HTML5 Canvas演示
  7. Linux 查看数据库MySQL安装文件和安装目录的命令
  8. SQL Server 2005 中行号的显示,分页
  9. 100万并发连接服务器笔记之Java Netty处理1M连接会怎么样
  10. 软件工程个人日报 2016/6/29
  11. 数学方法论选讲---第一章 引论
  12. WORD中的格式控制符号
  13. 拍一拍身上的土(2009-12-12 01:17:43韩寒博客)
  14. vue3动态加载组件
  15. Flutter IOS 提交AppStore 审核失败
  16. JZYZOJ1384 种花小游戏 状压dp
  17. 实验吧 因缺思汀的绕过 By Assassin(with rollup统计)
  18. 五、结构化分析与设计
  19. 什么是安全性测试(security testing)?
  20. Github项目解析(五)--Android日志框架

热门文章

  1. python写透视挂_OpenCV的Python透视变换
  2. 10、SpringBoot之SpringAop的认识
  3. 坐商行商,你准备好了吗?
  4. Sql语句中between与in的用法详解
  5. 素描纸制品绘画攻略,掌握规律变简单~
  6. UG.NX.I-Deas.v6.0-ISO\
  7. 【latex】itemize, enumerate枚举,编号使用
  8. 超声功率放大器原理(超声功率放大器的作用是什么)
  9. python海龟作图画爱心_python1|海龟作图法
  10. linux 找到安装的软件包,如何在 Linux 中列出可用的软件包组