java中如何排查死锁,有哪些方法

死锁代码

java 复制代码
public void threadLock() {
    Thread thread1 = new Thread(() -> {
        synchronized (resource1) {
            System.out.println(Thread.currentThread().getName() + " got resource1 lock.");
            try {
                Thread.sleep(100); // 模拟工作时间,让死锁更容易观察到
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName() + " trying to get resource2 lock.");
            synchronized (resource2) { // 尝试获取resource2的锁
                System.out.println(Thread.currentThread().getName() + " got resource2 lock.");
            }
        }
    }, "Thread 1");

    Thread thread2 = new Thread(() -> {
        synchronized (resource2) {
            System.out.println(Thread.currentThread().getName() + " got resource2 lock.");
            try {
                Thread.sleep(100); // 模拟工作时间
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName() + " trying to get resource1 lock.");
            synchronized (resource1) { // 尝试获取resource1的锁
                System.out.println(Thread.currentThread().getName() + " got resource1 lock.");
            }
        }
    }, "Thread 2");

    thread1.start();
    thread2.start();
}

1. 使用 jstack 命令

jstack 属于 JDK 自带的工具,能够打印出 Java 进程中线程的堆栈信息,从而协助发现死锁。

  • 步骤

    1. 先通过 jps 命令获取 Java 进程的 ID。
    2. 再使用 jstack <pid> 命令打印线程的堆栈信息。
    3. 查看输出结果,若存在死锁,jstack 会给出相关提示。
  • 示例

bash

yaml 复制代码
# 获取Java进程ID
jps
# 假设进程ID为1234,打印线程堆栈信息
jstack 1234

2. 使用 VisualVM 工具

VisualVM 是一个可视化的监控工具,它能查看 Java 应用程序的性能和线程信息,也能检测死锁。

  • 步骤

    1. 打开 VisualVM 工具。
    2. 选择要监控的 Java 进程。
    3. 切换到 "线程" 标签页,点击 "线程 Dump" 按钮。
    4. 若存在死锁,VisualVM 会以图形化方式展示。

3. 使用 Java Mission Control(JMC)

Java Mission Control 是一个功能强大的工具,可用于监控和分析 Java 应用程序。它能实时监控线程状态,检测死锁。

  • 步骤

    1. 打开 Java Mission Control 工具。
    2. 连接到要监控的 Java 进程。
    3. 在 "线程" 视图中查看线程状态,若存在死锁,JMC 会给出相应提示。

4. 使用 jdk自带的jconsole.exe

  • 步骤

    1. 进入到bin目录。
    2. 运行jconsole.exe。
    3. 连接到要监控的 Java 进程

5. 使用Arthas排查问题

  • 启动 Arthas: java -jar arthas-boot.jar

  • 查看总体使用情况: dashboard

可以看到已经有死锁线程了

  • 查看总体线程使用情况: thread

BLOCKED线程数量:2,并且显示了具体的BLOCKED线程

  • 定位死锁的位置: thread -b

查看死锁线程详细信息:
thread 49
thread 48

相关推荐
马猴烧酒.21 小时前
【面试八股|Java集合】Java集合常考面试题详解
java·开发语言·python·面试·八股
闻哥1 天前
从测试坏味道到优雅实践:打造高质量单元测试
java·面试·单元测试·log4j·springboot
计算机程序设计小李同学1 天前
基于 Spring Boot + Vue 的龙虾专营店管理系统的设计与实现
java·spring boot·后端·spring·vue
Charlie_lll1 天前
力扣解题-[3379]转换数组
数据结构·后端·算法·leetcode
南风知我意9571 天前
【前端面试5】手写Function原型方法
前端·面试·职场和发展
VX:Fegn08951 天前
计算机毕业设计|基于springboot + vue云租车平台系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
汤姆yu1 天前
2026基于springboot的在线招聘系统
java·spring boot·后端
计算机学姐1 天前
基于SpringBoot的校园社团管理系统
java·vue.js·spring boot·后端·spring·信息可视化·推荐算法
java1234_小锋1 天前
Java高频面试题:SpringBoot如何自定义Starter?
java·spring boot·面试
hssfscv1 天前
Javaweb学习笔记——后端实战8 springboot原理
笔记·后端·学习