jconsole和jstack定位死锁问题

什么是死锁

死锁问题是多线程特有的问题,它可以被认为是线程间切换消耗系统性能的一种极端情况。 在死锁时,线程间相互等待资源,而又不释放自身的资源,导致无穷无尽的等待,其结果是系统任务永远无法执行完成。 死锁问题是在多线程开发中应该坚决避免和杜绝的问题.

死锁示例代码

package com.rumenz.learn.deadLock;

public class RumenzThread implements Runnable{
    int a,b;

    public RumenzThread(int a, int b) {
        this.a = a;
        this.b = b;
    }

    @Override
    public void run() {
       //Integer.valueOf(a) 包装成对象
        synchronized (Integer.valueOf(a)){
            try{
                //睡眠3秒,增加死锁的几率
                Thread.sleep(3000);

            }catch (Exception e){
                e.printStackTrace();
            }
            synchronized (Integer.valueOf(b)){
                System.out.println("a+b="+(a+b));
            }
        }

    }
}

package com.rumenz.learn.deadLock;

public class DeadLock {

    public static void main(String[] args) {
        new Thread(new RumenzThread(1, 2)).start();
        new Thread(new RumenzThread(2, 1)).start();

    }
}

运行程序使用jstack -l pid来定位死锁

先找到死锁程序的进程id

> jps
56993 Jps
56636 Launcher
57066 DeadLock  //这个就是死锁的进程

使用jstack -l 57066来定位死锁

> jstack -l 57066


Found one Java-level deadlock:
=============================
"Thread-1":
  waiting to lock monitor 0x00007fbe6d80de18 (object 0x000000076ab33988, a java.lang.Integer),
  which is held by "Thread-0"
"Thread-0":
  waiting to lock monitor 0x00007fbe6d8106a8 (object 0x000000076ab33998, a java.lang.Integer),
  which is held by "Thread-1"

Java stack information for the threads listed above:
===================================================
"Thread-1":
	at com.rumenz.learn.deadLock.RumenzThread.run(RumenzThread.java:27)
	- waiting to lock <0x000000076ab33988> (a java.lang.Integer)
	- locked <0x000000076ab33998> (a java.lang.Integer)
	at java.lang.Thread.run(Thread.java:748)
"Thread-0":
	at com.rumenz.learn.deadLock.RumenzThread.run(RumenzThread.java:27)
	- waiting to lock <0x000000076ab33998> (a java.lang.Integer)
	- locked <0x000000076ab33988> (a java.lang.Integer)
	at java.lang.Thread.run(Thread.java:748)

Found 1 deadlock. //发现一个死锁

RumenzThread.java:27 定位到大概的代码文件位置。

jconsole定位死锁问题

  • 找到死锁进程

image-20210131232115142

  • 链接,不安全的链接

    image-20210131232205381

  • 选择线程

    image-20210131232346154

  • 点击检测死锁

    image-20210131232434316

关注微信公众号:【入门小站】,解锁更多知识点。

posted @ 2021-01-31 23:37  入门小站  阅读(302)  评论(0编辑  收藏  举报