Java进程CPU占用高导致的网页请求超时的故障排查
一、发现问题的系统检查:一个管理平台门户网页进统计页面提示请求超时,随进服务器操作系统检查load average超过4负载很大,PID为7163的进程占用到了800%多。 二、定位故障根据这种故障的一般处理思路,先找出问题进程内CPU占用率高的线程,再通过线程栈信息找出该线程当时在运行的问题代码段,操作如下: 2.1、根据思路查看高占用的“进程中”占用高的“线程”,追踪发现7163的进程中16298的线程占用较高,使用命令: top -Hbp 7163 | awk '/java/ && $9>50' 显示结果:2.2、将16298的线程ID转换为16进制的线程ID。 printf "%x\n" 16298 3faa 2.3、通过jvm的jstack查看进程信息,发现是调用数据库的问题。 jstack 7163 | grep "3faa" -A 30 显示结果:2.4、既然是数据库的问题就检查数据库,思路是先打印了所有在跑的数据库线程,检查后发现跟进情况找到问题表: 2.4.1、打印mysql现有进程信息,并把信息生成log文件,使用的命令如下: mysql -u...
























