Linux操作系统内CPU占用率居高不下的解决办法,linux下cpu飙高原因排查过程详解,其实我们现在已经知道是谁把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行出的幺蛾子,我们进入代码验证
问题不大
破案
撒花
【Linux操作系统内CPU占用率居高不下的解决办法,linux下cpu飙高原因排查过程详解】到此这篇关于linux下cpu飙高原因排查过程详解的文章就介绍到这了,更多相关linux cpu飙高原因排查内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
Linux操作系统内CPU占用率居高不下的解决办法,linux下cpu飙高原因排查过程详解相关解决办法文章内容 。
推荐阅读
- Linux系统下LVM阵列增加硬盘扩容的操作教程方法,Linux里LVM磁盘扩容详细步骤
- 越野皮卡什么车型比较好,十五万以内?
- 夏普sh8118u为什么叫做点心操作系统?有什么特点?
- 小米2a哪个系统版本占内存最低,占多少
- 电脑操作系统有几种,操作系统的五大功能
- linus操作系统,操作系统不等于
- 内部处理机】荣耀手表,荣耀手表s1能解锁手机多少钱
- 曝腾讯大王卡内测无限流量套餐 腾讯大王卡可以办理几张
- 国内最好的山寨手机 假繁荣的山寨手机
- 开源虚拟机virtualbox内安装Linux系统OpenSuse教程大全,virtualbox上安装OpenSuse的方法