死锁及排查

概念

死锁是指两个或两个以上的线程在执行过程中,因抢夺资源而造成的一种互相等待的现象,若无外力干涉,则它们无法再继续推进下去。

产生原因

  • 系统资源不足
  • 进程运行推进顺序不合适
  • 系统资源分配不当

死锁及排查_第1张图片

死锁case

  • 线程A先获取a锁,再获取b锁。同时,线程B先获取b锁,再获取a锁
public class DeadLockDemo {
    static  Object a=new Object();
    static  Object b=new Object();

    public static void main(String[] args) {
        new Thread(() -> {
            synchronized (a){
                System.out.println("t1线程持有a锁,试图获取b锁");
                try {
                    TimeUnit.SECONDS.sleep(1);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                synchronized (b){
                    System.out.println("t1线程获取到b锁");
                }
            }
         },"t1").start();

        new Thread(() -> {
            synchronized (b){
                System.out.println("t2线程持有a锁,试图获取a锁");
                try {
                    TimeUnit.SECONDS.sleep(1);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                synchronized (a){
                    System.out.println("t2线程获取到a锁");
                }
            }
        },"t2").start();
    }
}

排查死锁

通过命令

  • 通过 jps -l 命令搜索可能出现死锁的进程信息

  • 通过 jstack 进程编号 可以排查死锁情况

图像化

jconsole工具

死锁及排查_第2张图片

死锁及排查_第3张图片

你可能感兴趣的:(java,jvm,开发语言)