飞道的博客

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

350人阅读  评论(0)

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


前置条件

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

yum install perf bcc-tools sysstat -y

通用分析流程

第一步、使用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
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场