linux下cpu飙高原因排查过程详解
目录
- 前言
- 开始
- 步骤
- 排查
前言
cpu飙高是很常见的线上问题,这都不会的话,属实有点拉跨

兄弟萌不用慌,来我教你一套连招
开始
先来个项目,整个api,到时候我们请求/cpu/{count}就能手动拉高cpu,机智鬼~
@GetMapping("/cpu/{count}")
public long cpuTest(@PathVariable("count") long count) {
long number = 0;
for (int i = 0; i < count; i++) {
number++;
}
return number;
}
打包、上传、启动

跑起来了,记住这个进程号 14849
我们先top看看正常情况下的cpu使用率

很合理
模拟线上cpu飙高
我们请求/cpu/{100000000000}接口,把cpu拉起来,同时top观察cpu使用率

直接干到98%,很nice
ok入戏,我们现在线上出问题了,cpu一直很高,老大叫你找找原因,开始支棱起来
其实我们现在已经知道是谁把cpu拉高了,但还不够细,只知道哪个项目出的问题远远不够,我们应该找到罪魁祸首,到底是哪个方法的多少行导致的问题,这才能让老大直呼内行
步骤
jps+top 定位应用进程
pidtop -Hp {pid}找到线程tid
将 tid 转换成十六进制 printf “%x\n” {tid}
打印堆栈信息 jstack
过滤出我们想要的
排查
进程id已经确定是 14849,下一步我们要找到是哪个线程搞的鬼
top -Hp 14849

很明显是这个14908搞的鬼
转十六进制

打印堆栈

堆栈信息显示是TestController里面的第20行出的幺蛾子,我们进入代码验证

问题不大
破案
撒花
您可能感兴趣的文章
- 01-12Docker部署rabbitmq遇到的两个问题
- 01-12最新虚拟机VMware 14安装教程
- 01-12使用docker compose安装harbor私有仓库的详细教程
- 01-12Windows下Docker安装各种软件的详细过程
- 01-12seata docker 高可用部署的详细介绍
- 01-12浅谈Tomcat多层容器的设计
- 01-12Gogs+Jenkins+Docker 自动化部署.NetCore的方法步骤
- 01-12解决vscode docker插件docker.socket权限问题
- 01-12Docker中运行PostgreSQL并推荐几款连接工具
- 01-12Docker核心原理之 Cgroup详解


阅读排行
推荐教程
- 12-07一文教你怎么选择Tomcat对应的JDK版本
- 12-23linux中ftp无法访问怎么办
- 12-11docker存储目录迁移示例教程
- 12-10docker start启动容器后仍然exit状态的解决
- 12-10Linux下如何安装Logstash
- 12-05Docker安装Jenkins全过程
- 01-05Shell脚本去重的几种方法实例
- 12-22kvm虚拟机配置NAT端口转发的实现方法
- 12-19Zabbix SAML SSO 登录绕过漏洞的操作流程
- 12-15Docker-Compose搭建Spark集群的实现方法




