使用top + jstack
- 使用命令行top,排查查是哪个进程占用cpu最高,获取到进程号,如:36032
- 再通过命令查出该进程下哪个线程占用cpu最高,如得到线程pid:36044
top -Hp 高cpu占用率的进程号
- 使用命令将36044转为十六位进制,得到:8ccc
printf %x 36044
jstack 36032 > 1.txt
- 最后使用命令,查询该线程异常的代码位置,分析上下文代码即可得出原因
# 找到文件中8ccc的位置,并显示后30行信息,即可找到具体代码位置
cat 1.txt | grep -A 30 8ccc
可能导致CPU占用率过高的场景与解决方案
正常情况:业务高峰
异常情况:
- 无限循环
- 频繁GC
- 频繁创建新对象
- 序列化与反序列化
- 正则表达式
- 频繁的线程上下文切换