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

 

posted @ 2022-01-17 17:43  修心而结网  阅读(56)  评论(0编辑  收藏  举报