Java死锁的排查

https://blog.csdn.net/sidihuo/article/details/52474227


先弄个死锁的代码例子:

[java]  view plain  copy
  1. public class DeadLock implements Runnable {  
  2.   
  3.     private int flagCurrent = -1;  
  4.   
  5.     private static int flagThread1 = 0;  
  6.   
  7.     private static int flagThread2 = 1;  
  8.   
  9.     private static Object object1 = new Integer(1);  
  10.   
  11.     private static Object object2 = new Double(2);  
  12.   
  13.     @Override  
  14.     public void run() {  
  15.   
  16.         System.out.println("CurrentThread" + flagCurrent);  
  17.   
  18.         if (flagCurrent == flagThread1) {// 线程1进  
  19.             synchronized (object1) {// 线程1先锁定object1(期间要等500ms去锁定object2)  
  20.                 try {  
  21.                     Thread.sleep(500);  
  22.                 } catch (final Exception e) {  
  23.                     e.printStackTrace();  
  24.                 }  
  25.                 // 此时线程2已经锁定object2,需要【等待】线程2释放object2,然后线程1锁定object2释放object2,再释放object1  
  26.                 // 死锁发生:线程1等待线程2释放object2,线程1才释放object1;线程2等待线程1释放object1,线程2才释放object2;  
  27.                 synchronized (object2) {  
  28.                     System.out.println("1");  
  29.                 }  
  30.             }  
  31.         }  
  32.         if (flagCurrent == flagThread2) {// 线程2进  
  33.             synchronized (object2) {// 线程2先锁定object2(期间要等500ms去锁定object1)  
  34.                 try {  
  35.                     Thread.sleep(500);  
  36.                 } catch (final Exception e) {  
  37.                     e.printStackTrace();  
  38.                 }  
  39.                 // 此时线程1已经锁定object1,需要【等待】线程1释放object1,然后线程2锁定object1释放object1,再释放object2  
  40.                 // 死锁发生:线程1等待线程2释放object2,线程1才释放object1;线程2等待线程1释放object1,线程2才释放object2;  
  41.                 synchronized (object1) {  
  42.                     System.out.println("0");  
  43.                 }  
  44.             }  
  45.         }  
  46.     }  
  47.   
  48.     public static void main(final String[] args) {  
  49.         final DeadLock runnableThread1 = new DeadLock();  
  50.         final DeadLock runnableThread2 = new DeadLock();  
  51.   
  52.         runnableThread1.flagCurrent = flagThread1;  
  53.         runnableThread2.flagCurrent = flagThread2;  
  54.   
  55.         new Thread(runnableThread1, "runnableThread1").start();  
  56.         new Thread(runnableThread2, "runnableThread2").start();  
  57.   
  58.     }  
  59. }  



查找死锁的2个方法:

1.用Jconsole

切换到线程那个选项卡,左下角有个死锁检查:



2.用Jstack

先jps 找出对应的代号,再Jstack -l  代号,就可看见了



Java 中可以使用以下方式来排查死锁: 1. 使用 jstack 工具 jstack 工具可以查看 Java 进程的线程状态和调用栈信息,通过分析线程状态和调用栈信息,可以发现是否存在死锁。 使用方式: ``` jstack <pid> ``` 其中,`<pid>` 是 Java 进程的进程号。 2. 使用 jconsole 工具 jconsole 工具可以查看 Java 进程的线程、内存、CPU 等信息,通过分析线程信息,可以发现是否存在死锁。 使用方式: 1. 启动 Java 进程时添加参数: ``` -Dcom.sun.management.jmxremote.port=<port> -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false ``` 其中,`<port>` 是 jconsole 连接 Java 进程的端口号。 2. 启动 jconsole 工具,输入连接信息: ``` Remote Process:<hostname>:<port> ``` 其中,`<hostname>` 是 Java 进程所在主机的 IP 地址或者域名,`<port>` 是 Java 进程的端口号。 3. 在 jconsole 工具中选择“线程”选项卡,查看线程状态和调用栈信息,分析是否存在死锁。 3. 使用 VisualVM 工具 VisualVM 工具是一款免费的 Java 监控和分析工具,可以查看 Java 进程的线程、内存、CPU 等信息,通过分析线程信息,可以发现是否存在死锁。 使用方式: 1. 启动 Java 进程时添加参数: ``` -Dcom.sun.management.jmxremote.port=<port> -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false ``` 其中,`<port>` 是 VisualVM 连接 Java 进程的端口号。 2. 启动 VisualVM 工具,选择“远程”选项卡,输入连接信息: ``` <hostname>:<port> ``` 其中,`<hostname>` 是 Java 进程所在主机的 IP 地址或者域名,`<port>` 是 Java 进程的端口号。 3. 在 VisualVM 工具中选择“线程”选项卡,查看线程状态和调用栈信息,分析是否存在死锁
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值