关于应用服务器资源消耗100%排查过程
背景:压测过程中发现应用服务器资源消耗达到满载状态,后端代码为java编写,容器化docker部署,定位思路如下:
1.使用常用的top c 命令查看当前消耗服务器资源的pid是否为java程序引起,避免其他程序干扰
2.docker ps 查看目前运行的容器id
3.进入容器 docker exec -it 容器id bash
4.使用top命令定位目前消耗的进程pid
5.cd /app/jdk1.8.0_121/bin/ 到jdk bin目录
ps -ef|grep java 看进程号 或容器下 ./jps
打dump日志
./jmap -dump:format=b,file=/applog/heap.hprof 进程号 (安装jdk但是未配置环境变量需要到jdk 安装bin目录下执行jstsck,jmap等命令)
利用MAT等分析工具分析内存
或者直接使用jstack -l pid 查看当前堆栈信息是否存在线程锁