假设生产环境出现CPU占用过高,请谈谈你的分析思路和定位

本文详细介绍了当遇到CPU使用率过高问题时,如何通过一系列步骤定位引起问题的代码行。从使用top命令找出CPU占比最高的进程,到进一步利用ps和jstack命令定位具体的后台程序及代码行,提供了实用的操作指南。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目的

找出引出问题的代码行!日志只能报错代码,不能解决cpu过高的问题

步骤

  1. 先用top命令找出cpu占比最高的
    确定进程PID
  2. ps -ef或者jps进一步定位,得知是一个怎么样的一个后台程序惹事
    ps -ef | grep 5101

5101 4063 36 08:25 pts/2 00:11:25 java club.eryastudio.test.Demo2

  1. 定位到具体线程或者代码

ps -mp 进程 -o THREAD,tid,time

ps -mp 1501 -o THREAD,tid,time
root 35.6 19 - - - - 5102 00:11:35


4.将需要的线程ID转换为16进制格式(英文小写格式)

将线程号5102转为小写16进制 13ee

5.jstack进程ID | grep(16进制线程ID小写英文) -A60

jstack 5101 | grep 13ee -A60

具体到某一行代码了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值