故障排查——负载Load过高(2)

本文介绍了一种简单的方法来排查CPU高负载的问题,包括查看高占用率的进程和线程,使用top命令及其参数进行深入分析,以及如何通过jstack定位具体的线程。

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

目录

传送门

排查步骤

查看CPU占用高进程

查看cpu占用高线程

转换线程ID

定位cpu占用线程

TOP命令补充


传送门

在前面介绍了一下load的相关概念及常用的几个命令,传送门:

故障排查——负载Load过高(1)

现在就学习一下简单的排查步骤,这个不是真实的生产案例,只此记录学习

排查步骤

查看CPU占用高进程

还是以top为例

看到占用最高的是Java进行,PID是117766

查看cpu占用高线程

命令:

top -H -p 117766

查看cup占用最多的线程

可以看到118030这个占用CPU比较高

转换线程ID

得到线程ID

定位cpu占用线程

命令:

jstack 117766|grep 1cd0e -A 50 --col

上面是一个JVM的调度线程。至此分析步骤完毕。

注意的是线上机器一般不允许jstack:可能是dump之后,拿到其它机器去分析

TOP命令补充

top命令交互

top命令控制台,我们可以按h或者?进入交互界面

比如改变颜色的Z

按0-7选择验收,然后按a或执行,最后按回车确认

常用参数

前面用的了命令

top -H -p 117766

p:通过指定监控进程ID来仅仅监控某个进程的状态:top –p 117766

 

只显示进程为117766的运行状况。

-H: 设置线程模式

显示某个进程所有活跃的线程消耗情况,设置线程模式下:第二行的tasks指的是线程个数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值