cpu load过高问题分析和解决

1. 首先排查哪些进程cpu占用率高。 通过命令 ps ux


2. 查看对应java进程的每个线程的CPU占用率。通过命令:ps -Lp 122427  cu



3.  追踪线程内部,查看load过高原因。通过命令:jstack pid。

以线程jpid为例,现将jpid转换成16进制XXXX。 再通过多次监控jstack日志,排查线程jpid的运行轨迹。


4. 通过jstack查看代码运行轨迹,结合已有源码,一般可以分析出死循环的地方。
cpu load的飙升,一方面可能和full gc的次数增大有关,一方面可能和死循环有关系,每次经验的积累,对于以后定位问题有非常大的好处,这些case积累起来是自己一生的财富,性能领域会把每次遇到的问题整编在这里,以便作为后续的知识分享打基础,更期待的是每次问题发生,能够抽象出一些产品或者工具,方便高效率发现问题和跟踪问题、解决问题


在cpu高的时候执行:

sudo ./jstack -l 13031 > /home/mydir/jstack.log
保存当前java堆执行现场,记录下当时占用比较高的线程pid(即top -H下的线程pid)
建议多开几个窗口同时监控记录。挑选上述几个线程pid:13243,、13654等,转成16进制
printf "%x\n" 13243
printf "%x\n" 13654
分别得到33bb、3556,查找刚才记录的java堆执行日志文件
cd /home/mydir/
vi jstack.log
查找33bb、3556这两个字符串,看到的结果如下:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值