java CPU高
what:
进程的CPU高,例如:服务没有流量,但是CPU使用近百:
why:
找到CPU占用居高不下的线程,然后通过栈信息进行分析代码中的具体原因。
how
通过进程,分析线程,找到CPU居高不下的线程。
具体步骤:
1、使用top 定位到占用CPU高的进程PID。命令:top
2、获取线程信息,并找到占用CPU高的线程。
命令1:ps -mp pid -o THREAD,tid,time | sort -rn
命令2:top -H -p PID
3、线程ID转换为16进制格式
命令1:echo “obase=16; tid” | bc
命令2:printf "%x\n" tid
4、打印线程的堆栈信息
jstack pid 或者 jstack pid |grep tid -A 30