问题描述:
生产环境下的某台tomcat7服务器,在刚发布时的时候一切都很正常,在运行一段时间后就出现CPU占用很高的问题,基本上是负载一天比一天高。tomcat
解决过程:服务器
一、根据top命令,发现PID为2633的Java进程占用CPU高达300%,出现故障。
二、找到该进程后,如何定位具体线程或代码呢,首先显示线程列表,并按照CPU占用高的线程排序:
[root@localhost 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排序
三、将须要的线程ID转换为16进制格式 进程
[root@localhost logs]# printf "%x\n" 3626
e18grep
四、打印线程的堆栈信息im
[root@localhost logs]# jstack 2633 |grep e18 -A 30sort