iis服务器助手广告
返回顶部
首页 > 资讯 > 操作系统 >linux下cpu飙高原因排查过程详解
  • 239
分享到

linux下cpu飙高原因排查过程详解

linux系统cpu占用率过高 2022-06-04 23:06:43 239人浏览 薄情痞子
摘要

目录前言开始步骤排查前言 cpu飙高是很常见的线上问题,这都不会的话,属实有点拉跨 兄弟萌不用慌,来我教你一套连招 开始 先来个项目,整个api,到时候我们请求/cpu/{count}就能手动拉高cpu,机智鬼~

目录
  • 前言
  • 开始
  • 步骤
  • 排查

前言

cpu飙高是很常见的线上问题,这都不会的话,属实有点拉跨

在这里插入图片描述

兄弟萌不用慌,来我教你一套连招

开始

先来个项目,整个api,到时候我们请求/cpu/{count}就能手动拉高cpu,机智鬼~


    @Get

EbvXOrut

Mapping("/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飙高原因排查内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

--结束END--

本文标题: linux下cpu飙高原因排查过程详解

本文链接: https://www.lsjlt.com/news/21418.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作