java 线程dump 对象_啃碎并发(四):Java线程Dump分析

1 Thread Dump介绍

1.1 什么是Thread Dump

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

1.2 Thread Dump特点

018428211de4e88dee72452ab3a4818b.png

1.3 Thread Dump抓取

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

1.操作系统命令获取ThreadDump

5c75c927ea248dabbe84f0554184a416.png

注意:

43a10c9f48aa74056ca4d6388103771f.png

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

3bb889e40a66afa9c1dc78cc94436be0.png

2 Thread Dump分析

2.1 Thread Dump信息

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

5c368e4f4946c7380ae7a902fd5f6c3b.png

2.线程INFO信息块:

f02a16bb937492d147f744a5111ba970.png

87ecaab77a2aecc0d6c7e77adee6324e.png

3.Java thread statck trace详解:

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

48e423d354e424c75b38a90cb065fe29.png

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值