当前位置: 首页 > article >正文

java如何查看线程死锁?

jstack

jstack是Java虚拟机自带的一种堆栈跟踪工具,可以用来打印出给定Java进程ID(PID)的Java线程的堆栈跟踪信息。通过多次执行jstack命令并观察输出结果,可以判断是否存在线程死锁。步骤:1. 首先,找到Java进程的PID。可以使用jps命令列出所有Java进程及其PID。2. 然后,使用jstack 命令查看该进程的线程堆栈信息。3. 多次执行jstack命令,观察输出结果中是否有线程状态长时间保持不变,且处于等待对方释放锁的状态,这通常表明存在死锁。

使用jconsole和jvisualvm

这两个工具都是Java监控和管理控制台(JMX)的一部分,提供了图形界面来查看和管理Java应用程序。步骤:• 启动jconsole或jvisualvm,连接到正在运行的Java应用程序。• 在工具中查看线程状态,特别是寻找处于BLOCKED状态的线程,这些线程可能正在等待获取锁。• jvisualvm还提供了线程转储(Thread Dump)功能,可以直接查看线程的堆栈信息,便于分析死锁

以下是一个简单的Java线程死锁示例:

public class DeadlockExample {
    private static final Object resource1 = new Object();
    private static final Object resource2 = new Object();

    public static void main(String[] args) {
        Thread thread1 = new Thread(() -> {
            synchronized (resource1) {
                System.out.println("Thread 1: Locked resource 1");
                try {
                    Thread.sleep(100);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                synchronized (resource2) {
                    System.out.println("Thread 1: Locked resource 2");
                }
            }
        });

        Thread thread2 = new Thread(() -> {
            synchronized (resource2) {
                System.out.println("Thread 2: Locked resource 2");
                try {
                    Thread.sleep(100);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                synchronized (resource1) {
                    System.out.println("Thread 2: Locked resource 1");
                }
            }
        });

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

线程1首先锁定resource1,然后尝试锁定resource2;线程2首先锁定resource2,然后尝试锁定resource1。由于两个线程都持有一个资源并等待另一个资源,从而形成了死锁。

jstack打印Java线程的堆栈跟踪信息手动分析线程死锁

jconsole图形界面查看和管理Java应用程序动态监控线程状态

jvisualvm图形界面监控和管理Java应用程序,提供线程转储功能动态监控和详细分析线程死锁

参考 https://mp.weixin.qq.com/s/9lVfXpvKpuUCmAlKtpEiHw


http://www.kler.cn/news/327102.html

相关文章:

  • tesseract:一个.Net版本的开源OCR项目
  • element-plus 日历组件 Calendar设置每周第一天为周一-非国际化版
  • MobaXterm基本使用 -- 服务器状态、批量操作、显示/切换中文字体、修复zsh按键失灵
  • 从0学习React(3)
  • C# 解决Excel边框样式无法复制问题及实现格式刷功能
  • 前端DOM常用操作
  • 什么是IIC通信协议?
  • JAVA姓氏头像情侣头像家庭头像签名头像谐音顽埂头像设计小程序头像大全系统小程序源码
  • sentinel2 L2A处理基线04.00 反射率计算方法
  • 【MySQL】视图和触发器
  • 使用代理爬取数据需要筛选合适的ip吗
  • C++11 多线程编程-小白零基础到手撕线程池
  • 【VUE】案例:商场会员管理系统
  • find()和findIndex()方法
  • 微信小程序——音乐播放器
  • 【有啥问啥】二分图(Bipartite Graph)算法原理详解
  • SpringMVC源码-AbstractUrlHandlerMapping处理器映射器将实现Controller接口的方式定义的路径存储进去
  • 健康生活,从日常细节开始
  • NVLM多模态 LLM 在图像和语言任务中的表现优于 GPT-4o
  • Oracle数据恢复—异常断电导致Oracle数据库报错的数据恢复案例
  • 第167天:应急响应-日志自动提取分析项目_ELK_Logkit_LogonTracer_Anolog等
  • Mysql高级篇(下)——日志
  • Microsoft Edge 五个好用的插件
  • MySQL存储过程循环操作
  • LVGL 笔记
  • SpringBoot3+Swagger3(最新版springdoc-openapi教程)
  • 组合优化与凸优化 学习笔记5 对偶拉格朗日函数
  • 21 vue3之发布npm插件(hook自定义指令)
  • 国产RISC-V案例分享,基于全志T113-i异构多核平台!
  • 【刷题6】一维前缀和、二维前缀和