实用脚本:检查高CPU/内存消耗进程

运维 系统运维
本教程中包含两个脚本,它们可以帮助你确定 Linux 上高 CPU/内存消耗进程的运行时间。该脚本将显示进程 ID、进程的所有者、进程的名称以及进程的运行时间。

[[336102]]

过去,我们写了三篇不同的文章来使用 Linux 命令来识别这些进程。

你可以通过下面相关的 URL 立即访问:

本教程中包含两个脚本,它们可以帮助你确定 Linux 上高 CPU/内存消耗进程的运行时间。

该脚本将显示进程 ID、进程的所有者、进程的名称以及进程的运行时间。这将帮助你确定哪些(必须事先完成)作业正在超时运行。这可以使用 ps 命令来实现。

什么是 ps 命令

ps 是进程状态processes status,它显示有关系统上活动/正在运行的进程的信息。

它提供了当前进程的快照以及详细信息,例如用户名、用户 ID、CPU 使用率、内存使用率、进程开始日期和时间等。

1)检查高 CPU 消耗进程在 Linux 上运行了多长时间的 Bash 脚本

该脚本将帮助你确定高 CPU 消耗进程在 Linux 上运行了多长时间。

  1. # vi /opt/scripts/long-running-cpu-proc.sh
  2.  
  3. #!/bin/bash
  4. ps -eo pid,user,ppid,%mem,%cpu,cmd --sort=-%cpu | head | tail -n +2 | awk '{print $1}' > /tmp/long-running-processes.txt
  5. echo "--------------------------------------------------"
  6. echo "UName PID CMD Process_Running_Time"
  7. echo "--------------------------------------------------"
  8. for userid in `cat /tmp/long-running-processes.txt`
  9. do
  10. username=$(ps -u -p $userid | tail -1 | awk '{print $1}')
  11. pruntime=$(ps -p $userid -o etime | tail -1)
  12. ocmd=$(ps -p $userid | tail -1 | awk '{print $4}')
  13. echo "$username $userid $ocmd $pruntime"
  14. done | column -t
  15. echo "--------------------------------------------------"

给 long-running-cpu-proc.sh 设置可执行的 Linux 文件权限

  1. # chmod +x /opt/scripts/long-running-cpu-proc.sh

运行此脚本时,你将获得类似以下的输出:

  1. # sh /opt/scripts/long-running-cpu-proc.sh
  2.  
  3. ----------------------------------------------------
  4. UName PID CMD Process_Running_Time
  5. ----------------------------------------------------
  6. daygeek 5214 Web 01:18:48
  7. daygeek 5748 Web 01:08:20
  8. daygeek 8043 inkscape 22:11
  9. daygeek 5269 Web 01:18:31
  10. daygeek 1712 Web 10:44:50
  11. daygeek 5335 RDD 01:17:54
  12. daygeek 1639 firefox 10:44:51
  13. daygeek 7793 nautilus 24:14
  14. daygeek 6301 Web 57:40
  15. ----------------------------------------------------

2)检查高内存消耗进程在 Linux 上运行了多长时间的 Bash 脚本

该脚本将帮助你确定最大的内存消耗进程在 Linux 上运行了多长时间。

  1. # sh /opt/scripts/long-running-memory-proc.sh
  2.  
  3. #!/bin/bash
  4. ps -eo pid,user,ppid,%mem,%cpu,cmd --sort=-%mem | head | tail -n +2 | awk '{print $1}' > /tmp/long-running-processes-1.txt
  5. echo "--------------------------------------------------"
  6. echo "UName PID CMD Process_Running_Time"
  7. echo "--------------------------------------------------"
  8. for userid in `cat /tmp/long-running-processes-1.txt`
  9. do
  10. username=$(ps -u -p $userid | tail -1 | awk '{print $1}')
  11. pruntime=$(ps -p $userid -o etime | tail -1)
  12. ocmd=$(ps -p $userid | tail -1 | awk '{print $4}')
  13. echo "$username $userid $ocmd $pruntime"
  14. done | column -t
  15. echo "--------------------------------------------------"

给 long-running-memory-proc.sh 设置可执行的 Linux 文件权限。

  1. # chmod +x /opt/scripts/long-running-memory-proc.sh

运行此脚本时,你将获得类似以下的输出:

  1. # sh /opt/scripts/long-running-memory-proc.sh
  2.  
  3. ----------------------------------------------------
  4. UName PID CMD Process_Running_Time
  5. ----------------------------------------------------
  6. daygeek 1639 firefox 10:44:56
  7. daygeek 2997 Web 10:39:54
  8. daygeek 5269 Web 01:18:37
  9. daygeek 1712 Web 10:44:55
  10. daygeek 8043 inkscape 22:17
  11. daygeek 5214 Web 01:18:54
  12. daygeek 1898 Web 10:44:48
  13. daygeek 1129 Xorg 10:45:07
  14. daygeek 6301 Web 57:45
  15. ----------------------------------------------------

 

 

责任编辑:庞桂玉 来源: Linux中国
相关推荐

2022-05-27 11:59:22

Linux内存CPU

2018-11-01 10:59:52

Linux内存进程

2019-08-23 06:22:47

LinuxShell监控脚本

2021-11-29 20:44:31

Linux内存进程

2019-08-28 06:58:06

Linux监控脚本Shell

2019-12-16 10:43:38

Linux内存消耗进程

2019-11-06 15:58:54

Linux内存消耗进程

2013-11-27 16:32:51

宕机kswapd0CPU

2023-03-05 16:40:07

linux进程内存

2011-03-23 14:42:47

CPU过度消耗

2017-01-12 15:17:27

线程CPU定位

2019-06-03 10:30:42

MySQLCPU数据库

2019-12-16 11:00:04

LinuxCPU进程

2019-12-16 09:10:38

Linux中央处理器进程

2018-05-31 11:58:06

Linux进程Early OOM

2021-01-08 13:00:12

CPU处理器软件

2021-02-26 13:35:46

JavaCPU内存

2011-07-06 09:11:40

MozillaFirefox

2015-04-20 10:20:20

高并发Web服务内存和CPU

2009-07-09 18:25:31

MyEclipse消耗
点赞
收藏

51CTO技术栈公众号