文章目录

  • 前言
  • 一、第一步 top
  • 二、根据pid查找具体线程
  • 2.根据pid找到16进制
  • 3. 根据进程和线程查找原因
  • 总结
  • 磁盘读写



前言

系统cpu飙高,尤其对于后端人员来说,其实应该学会排查,这样也算是综合能力的体现;那么当出现了cpu严重飙高的时候怎么排查呢?


一、第一步 top

直接在问题服务器输入命令: top

linux服务器CPU飙高排查_java环境

二、根据pid查找具体线程

top -Hp 13702

linux服务器CPU飙高排查_java环境_02


例如第一个就是这个进程下占用较高的线程 pid 是 13702

2.根据pid找到16进制

printf "%x" 13702

linux服务器CPU飙高排查_java环境_03


可以看到3586就是就是这个线程了

3. 根据进程和线程查找原因

jstack 13702 |grep 3586

总结

经过一些列操作,基本可以定位大部分问题,执行第三步的命令的时候,如果报 jstack 未找到命令, 应该是java环境没配置好,或者重新 source /etc/profile 之后,再次执行,应该就行了

磁盘读写

5s 刷新一次

vmstat -t 5