Linux CPU 占用率 100% 排查

Linux CPU 占用率 100% 排查

总体来说分为五个步骤

  1. top 命令定位应用进程 pid
  2. top -Hp [pid] 定位应用进程对应的线程 tid
  3. printf “%x\n” [tid] 将 tid 转换为十六进制
  4. jstack [pid] | grep -A 10 [tid 的十六进制] 打印堆栈信息
  5. 根据堆栈信息分析问题

以下为实战例子

写一段死循环代码:

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/*** CPU占用率测试方法*/
@RequestMapping("/api")
@RestController
public class CpuTestController {@GetMapping("/cpu/{count}")public long cpuRunning(@PathVariable("count") long count) {long result = 0;for (int i = 0; i < count; i++) {result++;}return result;}
}

调用接口

curl http://localhost:9999/api/cpu/10000000000,发现 CPU 一会儿就飙到了 100%,接下来我们按五步法探个究竟。

第一步:找到最耗 CPU 的进程 pid

// 执行 top 命令,按shift + p 组合键,按照CPU占用率排序
> top 

在这里插入图片描述
从图中,我们可以看到进程 pid 为 11168 的占用 CPU 是最高的,直接是 100%。

第二步:找到最耗 CPU 的线程 tid

// 执行 top -Hp [pid] 定位应用进程对应的线程 tid
// 按shift + p 组合键,按照CPU占用率排序
> top -Hp 11168

在这里插入图片描述
从图中,我们可以看到线程 tid 为 11196 占用 CPU 是最高的,达到 99.9%。

第三步:将线程 pid 转化为 16 进制

// printf "%x\n" [tid]  将tid转换为十六进制
> printf "%x\n" 11196
2bbc

在这里插入图片描述

第四步:查看线程的堆栈信息

// jstack [pid] | grep -A 10 [tid的十六进制]  打印堆栈信息
> jstack 11168 | grep -A 10 2bbc

在这里插入图片描述
我们不难发现原来是 CpuTestController 的第 24 行搞的鬼。

第五步:根据堆栈信息分析问题

找到对应的代码看一下,果真如此,问题已定位,优化代码逻辑吧~~~~

当然,除了使用上面的基础方法外,还有很多工具可以直接使用,例如阿里的

在这里插入图片描述
对于线上问题定位来说,分秒必争,所以我们在编码过程中,除了要实现业务功能交付,还要追求代码质量,要写出更高效、更优雅的代码。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/578140.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQLBolt,一个练习SQL的宝藏网站

知乎上有人问学SQL有什么好的网站&#xff0c;这可太多了。 我之前学习SQL买了本SQL学习指南&#xff0c;把语法从头到尾看了个遍&#xff0c;但仅仅是心里有数的程度&#xff0c;后来进公司大量的写代码跑数&#xff0c;才算真真摸透了SQL&#xff0c;知道怎么调优才能最大化…

Autosar-Mcal配置详解(免费)-MCU

3.6.1创建、配置RAM 1)配置MCU通用配置项 MCU的通用配置项可参考以下配置&#xff1a; 各配置项的说明如下&#xff1a; Wake Up Factor Clear Isr: 是否在唤醒的中断服务函数中清除Wakeup Factor Wake Up Factors Clear Centralised: 是否在shutdown前集中集中清除Wakeu…

OpenHarmony动效示例-如何使用animateTo实现显式动画。

介绍 利用ArkUI组件不仅可以实现局部属性变化产生的属性动画&#xff0c;也可以实现父组件属性变化引起子组件产生过渡效果式的全局动画即显式动画。效果如图所示&#xff1a; 相关概念 显式动画&#xff1a;提供全局animateTo显式动画接口来指定有闭包代码导致的状态变化插入…

HarmonyOS 应用开发之启动/停止本地PageAbility

启动本地PageAbility PageAbility相关的能力通过featureAbility提供&#xff0c;启动本地Ability通过featureAbility中的startAbility接口实现。 表1 featureAbility接口说明 接口名接口描述startAbility(parameter: StartAbilityParameter)启动Ability。startAbilityForRes…

论文笔记:TALK LIKE A GRAPH: ENCODING GRAPHS FORLARGE LANGUAGE MODELS

ICLR 2024&#xff0c;reviewer评分 6666 1 intro 1.1 背景 当下LLM的限制 限制1&#xff1a;对非结构化文本的依赖 ——>模型有时会错过明显的逻辑推理或产生错误的结论限制2&#xff1a;LLMs本质上受到它们训练时间的限制&#xff0c;将“最新”信息纳入到不断变化的世…

如何保证redis里的数据都是热点数据

MySQL 里有 2000w 数据&#xff0c;Redis 中只存 20w 的数据&#xff0c;如何保证 redis 中的数据都是热点数据&#xff1f; 1.Redis 过期删除策略 1&#xff09;惰性删除:放任键过期不管&#xff0c;但是每次从键空间中获取键时&#xff0c;都检查取得的键是否过期&#xff0c…

FMEA与智能机器人:提升机器人可靠性与安全性的关键

随着科技的飞速发展&#xff0c;智能机器人已经深入到我们生活的方方面面&#xff0c;从工业生产到家庭服务&#xff0c;从深海探险到太空探索&#xff0c;处处都有它们的身影。然而&#xff0c;随着应用的日益广泛&#xff0c;机器人系统的复杂性和不确定性也在增加&#xff0…

学习笔记——C语言基本概念函数——(9)

今天开始函数的学习 目录 1、函数的基本概念 1.1函数的意义 1.2函数的分类 2自定义函数 2.1自定义函数的整个过程 函数定义 函数声明 函数调用 实参 形参和实参的关系 2.2函数传参 地址传递 2.3static的使用 1、函数的基本概念 1.1函数的意义 概念&#xff1a;一…

自定义协议 ,序列化和反序列化

目录 ​编辑 一&#xff0c;问题引入&#xff1a; 二&#xff0c;协议 三&#xff0c;自定义协议 1&#xff0c;协议 2, 序列化和反序列化 四&#xff0c;网络版本的计算器 1&#xff0c;协议的定制 2&#xff0c;计算逻辑 3&#xff0c;服务端 4&#xff0c;客户端 …

基于Spring Boot 3 + Spring Security6 + JWT + Redis实现接口资源鉴权

紧接上一篇文章&#xff0c;基于Spring Boot 3 Spring Security6 JWT Redis实现接口资源鉴权 系列文章指路&#x1f449; 系列文章-基于SpringBoot3创建项目并配置常用的工具和一些常用的类 项目源码&#x1f449; /shijizhe/boot-test 文章目录 1. 修改 UserDetailsServic…

U盘文件突然消失:原因分析与恢复策略

U盘遭遇“幽灵”之手&#xff0c;文件不翼而飞 你是否曾遭遇过这样的诡异情况&#xff1a;前一天还好好存放在U盘里的文件&#xff0c;第二天却突然消失得无影无踪&#xff1f;这简直就像是一场无声的灾难&#xff0c;令人措手不及。U盘作为我们日常工作和生活中不可或缺的数据…