生产环境CPU过高问题定位

Posted 异想天开

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了生产环境CPU过高问题定位相关的知识,希望对你有一定的参考价值。

问题描述:
       生产环境下的某台tomcat7服务器,在刚发布时的时候一切都很正常,在运行一段时间后就出现CPU占用很高的问题,基本上是负载一天比一天高。

解决过程:

    1、根据top命令,发现PID为2633的Java进程占用CPU高达300%,出现故障。
    2、找到该进程后,如何定位具体线程或代码呢,首先显示线程列表,并按照CPU占用高的线程排序:
      [[email protected] logs]# ps -mp 2633 -o THREAD,tid,time | sort -rn

    显示结果如下:
       USER     %CPU PRI SCNT WCHAN  USER SYSTEM   TID     TIME
       root     10.5  19    - -         -      -  3626 00:12:48
       root     10.1  19    - -         -      -  3593 00:12:16

    3、将需要的线程ID转换为16进制格式 

       [[email protected] logs]# printf "%x\n" 3626
       e18

  4、打印线程的堆栈信息

     [[email protected] logs]# jstack 2633 |grep e18 -A 30

以上是关于生产环境CPU过高问题定位的主要内容,如果未能解决你的问题,请参考以下文章

开发经验java服务生产环境CPU使用过高解决思路

[转]生产环境中程序占用cpu过高的程序的排查办法

生产环境10分钟黄金时间快速排障:CPU不定时飙高怎么排查?

JVM调优 快速定位服务CPU过高(理论+实战)

生产环境如何快速跟踪分析定位问题-Java

Linux生产环境下---问题指标面试