【JVM基础19】——实践-CPU飙高排查方案和思路?

目录

  • [1- 引言:](#1- 引言:)
  • [2- ⭐核心:](#2- ⭐核心:)
    • [2-1 排查方案与思路](#2-1 排查方案与思路)
  • [3- 小结:](#3- 小结:)
    • [3-1 如何排查 CPU 飙高问题?](#3-1 如何排查 CPU 飙高问题?)

1- 引言:

  • CPU 飙高指的是项目在运行过程中导致服务器的 CPU 内存占用较高。

2- ⭐核心:

2-1 排查方案与思路

  1. 使用 top 命令查看占用 CPU 的情况
bash 复制代码
top
  1. 通过 top 命令查看后,可以查看是哪一个进程占用 CPU 较高,上图所示为 2266
  • 找到进程之后,目的是找到 java 项目中的哪一行代码导致 CPU 飙高的问题,由于代码的运行都是在线程中运行,
  1. 使用 ps 的 Linux 指令
bash 复制代码
ps -H -eo pid,tid,%cpu | grep 2266
  • 打印出了所有 2266 进程中的线程,可以看到其中 2276 占用 CPU 特别高
  1. 使用 一下 jstack + 进程 id
bash 复制代码
jstack 2266
  • 此时打印出所有线程的信息,可需要筛选出 上述 CPU 占用高的线程,2276
  • 同时 jstack 打印的信息中的线程 id 都是十六进制,因此需要通过 Linux 命令将十进制转为 十六进制
  1. 使用 Linux 将十进制线程 id 转为 十六进制
  • 通过 十六进制 的线程 id 找到对应的信息,定位到代码行
bash 复制代码
printf "%x\n" 2276

3- 小结:

3-1 如何排查 CPU 飙高问题?

相关推荐
z44247532618 分钟前
MySQL如何配置自动清理失效事务锁_结合定时任务清理
jvm·数据库·python
qq_3729069335 分钟前
怎么通过宝塔面板对网站数据库进行深度碎片整理_使用Optimize命令优化表空间资源占用
jvm·数据库·python
_F_y1 小时前
C++11 异步操作实现线程池
java·jvm·c++
2401_871492851 小时前
Vue.js计算属性computed依赖追踪与副作用函数effect关联机制
jvm·数据库·python
2401_882273721 小时前
SQL如何快速提取分组中最晚时间点数据_结合窗口函数实现
jvm·数据库·python
2301_814809862 小时前
如何用 cookie 的 HttpOnly 与 Secure 属性防范 XSS 攻击
jvm·数据库·python
m0_515098422 小时前
如何用 Object.keys 与 getOwnPropertyNames 遍历键名
jvm·数据库·python
qq_189807032 小时前
golang如何实现日志按级别过滤_golang日志按级别过滤实现教程
jvm·数据库·python
abc123456sdggfd2 小时前
Golang map底层实现原理_Golang map哈希表原理教程【经典】
jvm·数据库·python
justjinji2 小时前
JavaScript中利用宏任务拆分阻塞任务的实操案例
jvm·数据库·python