通过宝塔面板发现服务器突然负载状态100%
接着使用top命令查看了一下,发现cpu利用率很低,load却很高
通过使用 ps -axjf命令查看是否存在D状态进程
D 状态是指不可中断的睡眠状态,该状态的进程无法被 kill,也无法自行退出,只能通过恢复其依赖的资源或者重启系统来解决。。
通过排查,发现存在D状态进程
那么接下来就不用我说了吧,大家应该也知道怎么操作了。。。
如果发现没有D状态
1、需要打印出线程信息来分析,使用
jstack -l pid > jstack.log 如jstack -l 14 > jstack.log
2、然后使用
top -Hp pid 查出最占cpu的线程 如top -Hp 14
3、使用
printf “%x\n” pid 得到最耗时的PID需要转换成16进制
4、将得到的16进制值在 jstack.log中搜索找到线程信息
最后根据实际情况来解决