飞道的博客

通过jstack分析cpu问题

311人阅读  评论(0)

这个命令不是用来分析内存泄漏的,使用来分析线程问题的。
引用下之前写过的一个东西,可能会有帮助:

工作填坑记,关于cpu100%只能通过jstack txt文件分析原因

背景
工作中客户嵌入我们的agent,导致cpu飙升到100%,给搞挂了,客户已经删了agent相关所有文件,将agent剔除了。
线索:在这之前客户把平台关了。
提供了jstack文件
之前学习jvm的时候,了解过一些jstack
基于商业机密,不方便粘贴相关jstack文件。

分析
通过jstack相关操作查看哪个线程导致的,分别需要命令
1 top
2 top -Hp
3 jstack pid | grep pid
可是客户已经剔除了agent,现在执行top,也无法复现问题
通过dump的jstack文件分析问题
嗯,不解释了
解决
通过翻看博客https://www.jianshu.com/p/51052aaac3be 对于jstack的相关复习了一遍,收益颇丰,可是只能通过jstask分析,需要对每一个线程的状态有一定的了解。
如下的博客https://www.cnblogs.com/rainy-shurun/p/5732341.html,末尾部分,有很详细的分析,感谢!!!(建议自己认真阅读整篇文章)

其中这里的部分对于分析很有帮助

而我的jstack文件中,就有很多的waiting on condition,通过上面的描述是因为加载第三方资源网络的问题。

在我的jstack文件中有相关线程的名字,在项目中进行查看到相关的线程,发现是发送数据的问题,而之前说过,把后端服务关了,我们发送数据的线程受到了阻塞。

目前分析是这样的,可能不准确,等待后期更新。

相关连接
如何玩jstack:jstack 排查现成问题
真正解决本次问题:JVM监控命令详解(转),此博客原文:http://www.cnblogs.com/zhengyun_ustc/archive/2013/03/18/tda.html
我特地转载了一下自己记录下:https://blog.csdn.net/dataiyangu/article/details/102630271


转载:https://blog.csdn.net/dataiyangu/article/details/103833360
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场