技术开发 频道

当CPU在飙高时,它到底做了些什么呢?

  【IT168 评论】在开发过程中,有时候我们发现JVM占用的CPU居高不下,跟我们的预期不符,这时,CPU在做什么呢?是什么线程让CPU如此忙碌呢?我们通过如下几步,可以查看CPU在执行什么线程。

  1.查找jvm进程ID: jps -lv 或者 ps aux | grep java

  2.根据pid,查找占用cpu较高的线程:ps -mp pid -o THREAD,tid,time 如图所示:找到占用cpu最高的tid (可以使用sort命令排序:sort -k 3 -r -n)

当CPU在飙高时,它到底做了些什么呢?

当CPU在飙高时,它到底做了些什么呢?

  3.将tid转换为16进制的数字:printf “%x\n” tid

当CPU在飙高时,它到底做了些什么呢?

  4.使用jstack命令,查询线程信息,从而定位到具体线程和代码:jstack pid | grep 7ccd -A 30

当CPU在飙高时,它到底做了些什么呢?

  这样,你就看到CPU这么高,是什么线程在捣乱了!

  怎么样,是不是觉得有点儿麻烦,没有关系,我把这几个步骤写成了一个脚本,直接使用就OK了。

当CPU在飙高时,它到底做了些什么呢?

  

0