【Linux】针对cpu使用率高但无法找到进程分析套路(转载)

WEL测试:这是什么?我想看看,看了会不会中毒呀?有点害怕

前置条件
需要安装perf及bcc-tools、sysstat工具。以redhat为例,安装命令如下:

yum install perf bcc-tools sysstat -y
1
通用分析流程
第一步、使用top工具
观测CPU使用率是否过高;
观察running进程数与状态为R进程数量否一致,如果数量不一致,进行第二步。
第二步、针对R状态的进程进行分析
使用pidstat -p pid确认对应R状态的进程是否存在
使用ps aux | grep pid验证进程是否存在,与pidstat进行交叉验证
如果进程不存在,进行第三步,查找父进程

第三步、对应进程名的父进程
通过pstree 查找对应进程的父进程(pstree | grep 进程名称),找出出问题进程之后,执行第四步,获取更全面的性能数据进行分析。

第四步、录制当前系统性能指标数据
使用perf record -g对当前系统进程进行录制,录制时长大概15秒左右,按Ctrl+C退出录制。

第五步、分析数据找出异常调用
使用perf report 分析录制数据,找出异常数据指标,使用键盘方向键及回车键,查找到调用函数。

针对短时进程分析流程
第一步、使用top工具
观测CPU指标;观察running进程数与状态为R是否一致,如果书面不一致,进行第二步。

第二步、使用execsnoop工具获取父进程ID
该步骤需要安装bcc-tools工具,执行命令:/usr/share/bcc/tools/execsnoop 可以直接定位到父进程和子进程id。

第三步、录制当前系统性能指标数据
使用perf record -g对当前系统进程进行录制,录制时长大概15秒左右,按Ctrl+C退出录制。

第四步、分析数据找出异常调用
使用perf report 分析录制数据,找出异常数据指标,使用键盘方向键及回车键,查找到调用函数。

原文链接:https://blog.csdn.net/henni_719/article/details/107907768?utm_medium=distribute.pc_feed.none-task-blog-cf-3.nonecase&depth_1-utm_source=distribute.pc_feed.none-task-blog-cf-3.nonecase&request_id=5f439344cea070620e93eaa4

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值