linux – 如何查找过去一次运行的进程?

我被要求调查今天早上发生的高CPU使用率警报.我使用sar -p并看到当时出现的高CPU使用率

接下来我用ps -eo pcpu,pid,user,args | sort -r -k1 |更少列出这一小时的前10名记忆猪

现在,我如何找出在早上的特定时间导致瓶颈的流程.我是一名java开发人员,而不是Linux专家.

它甚至可能吗?

解决方法

有几种选择:

>使用一个脚本,定期将所需数据写入日志文件.您可以使用cron每隔x分钟将ps(和其他命令)的输出写入日志文件.
>更好的是使用专门的程序,为您完成此任务. atop非常擅长这一点,它负责日志文件的保留.

atop可通过CentOS / RHEL / Fedora的EPEL回购以及Debian / Ubuntu的默认回购获得.

您可以像普通的实时顶级实用程序一样使用atop,行为略有不同(请查看键盘的联机帮助页).

更有趣的部分是:安装后守护进程开始将数据记录到/ var / log / atop中,您可以再次使用atop读取这些文件:

atop -r /var/log/atop/atop_20160128

然后,您可以访问所有“顶级”功能(排序/查看内存/ CPU / IO使用情况等),您可以通过’t’向前跳10分钟,用’T’向前跳10分钟或跳转到通过’b’的特定时间.

查看atop联机帮助页面,谷歌有很多关于它的howtos.

可能还有其他解决方案,但在进行更多定制设置之前,atop易于理解和使用,并且是一个良好的开端.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


查找全部容器的日志文件 $ sudo find /var/lib/docker/containers -name *.log 查看日志位置 $ docker inspect --format='{{.LogPath}}' <container_name> 实时查询内容 $
Linux日志文件中列属性的详细解析
在Linux系统中没有duf命令,如何有效地管理磁盘空间?
深入探讨EncryptPad在Linux操作系统中的功能和优势
原理和应用场景:Linux中ttyload工具的工作原理和实际用途
深度解析SELinux的三种策略类型
评估Linux系统性能的ttyload工具使用效果
分享在Linux系统中检测SSH版本的方法
介绍Linux平台上的数据加密工具EncryptPad
在Linux系统中,如何查看和诊断块设备信息?
在Linux环境下如何查看块设备信息?
探索Linux操作系统下的数据加密工具EncryptPad
学会在Linux系统中查看硬盘信息
分析SELinux:原理与实践
掌握SELinux策略类别
技巧:有效解读和管理Linux日志文件
查看Linux系统中的所有用户
了解Linux系统中各种不同类型的日志文件
深入理解Linux PS命令
方法:在Linux操作系统中查看用户