深入研究Java线程Dump分析:掌握发现和解决多线程问题的关键技巧

本文深入探讨了Java线程Dump的用途和特性,介绍了如何抓取Thread Dump,以及如何分析Thread状态,包括NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING和TERMINATED等。通过对关键状态的分析,帮助开发者发现和解决多线程问题,例如死锁和热锁,并列举了CPU高负载、响应慢等场景下的问题排查方法。
摘要由CSDN通过智能技术生成

1 Thread Dump介绍

1.1 什么是Thread Dump

Thread Dump是非常有用的诊断Java应用问题的工具。每一个Java虚拟机都有及时生成所有线程在某一点状态的thread-dump的能力,虽然各个 Java虚拟机打印的thread dump略有不同,但是大多都提供了当前活动线程的快照,及JVM中所有Java线程的堆栈跟踪信息,堆栈信息一般包含完整的类名及所执行的方法,如果可能的话还有源代码的行数。

1.2 Thread Dump特点



4de0bf39e27c701bb84d118cecff72d8.jpeg



1.3 Thread Dump抓取

一般当服务器挂起,崩溃或者性能低下时,就需要抓取服务器的线程堆栈(Thread Dump)用于后续的分析。在实际运行中,往往一次 dump的信息,还不足以确认问题。为了反映线程状态的动态变化,需要接连多次做thread dump,每次间隔10-20s,建议至少产生三次 dump信息,如果每次 dump都指向同一个问题,我们才确定问题的典型性。



1.操作系统命令获取ThreadDump



94bbff8388f0269b0f076a6219a5e39a.jpeg



注意:



e69f6df7805784155dfea5ba90005fa8.jpeg



2.JVM 自带的工具获取线程堆栈



9b213c3a8a102ff516ad45e5d7138039.jpeg



2.1 Thread Dump信息

1.头部信息:时间,JVM信息



11ea844d7ef400606cd5cac89750c2b9.jpeg



2.线程INFO信息块:



72d1a562fddaa27d84fc2254bb994aa4.jpeg



de00eeb08a0223e1e73ba1f912ec8831.jpeg



3.Java thread statck trace详解:



堆栈信息应该逆向解读:程序先执行的是第7行,然后是第6行,依次类推。



142dcadd568408d2b92a76bc88cd598b.jpeg



也就是说对象先上锁,锁住对象0xb3885f60,然后释放该对象锁,进入waiting状态。为啥会出现这样的情况呢?看看下面的java代码示例,就会明白:



  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值