2020-01-07 00:55:40 +08:00
|
|
|
|
[#]: collector: (lujun9972)
|
2020-07-22 08:53:24 +08:00
|
|
|
|
[#]: translator: (geekpi)
|
2020-01-07 00:55:40 +08:00
|
|
|
|
[#]: reviewer: ( )
|
|
|
|
|
[#]: publisher: ( )
|
|
|
|
|
[#]: url: ( )
|
|
|
|
|
[#]: subject: (Bash Script to Check How Long the High CPU/Memory Consumption Processes Runs on Linux)
|
|
|
|
|
[#]: via: (https://www.2daygeek.com/bash-script-to-check-how-long-the-high-cpu-memory-consumption-processes-runs-on-linux/)
|
|
|
|
|
[#]: author: (Magesh Maruthamuthu https://www.2daygeek.com/author/magesh/)
|
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
在 Linux 中运行 Bash 脚本检查高 CPU/内存消耗进程
|
2020-01-07 00:55:40 +08:00
|
|
|
|
======
|
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
过去,我们写了三篇不同的文章来使用 Linux 命令来识别。
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
你可以通过下面相关的 URL 立即访问。
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
* **[如何在 Linux 中查找高 CPU 消耗进程][1]**
|
|
|
|
|
* **[如何找出 Linux 中的高内存消耗进程][2]**
|
|
|
|
|
* **[检查进程在 Linux 中运行了多长时间的五种方法][3]**
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
本教程中包含两个脚本,它们可以帮助你确定 Linux 上高 CPU/内存消耗进程的运行时间。
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
该脚本将显示进程 ID,进程的所有者,进程的名称以及进程的运行时间。
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
这将帮助你确定哪些(必须事先完成)作业正在超时运行。
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
在可以使用 ps 命令来实现。
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
### 什么是 ps 命令
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
ps 代表进程状态,它显示有关系统上活动/正在运行的进程的信息。
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
它提供了当前进程的快照以及详细信息,例如用户名、用户 ID、CPU 使用率、内存使用率、进程开始日期和时间等。
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
### 1)Bash 脚本检查高 CPU 消耗进程在 Linux 上运行了多长时间
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
该脚本将帮助你确定高 CPU 消耗进程在 Linux 上运行了多长时间。
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
# vi /opt/scripts/long-running-cpu-proc.sh
|
|
|
|
|
|
|
|
|
|
#!/bin/bash
|
|
|
|
|
ps -eo pid,user,ppid,%mem,%cpu,cmd --sort=-%cpu | head | tail -n +2 | awk '{print $1}' > /tmp/long-running-processes.txt
|
|
|
|
|
echo "--------------------------------------------------"
|
|
|
|
|
echo "UName PID CMD Process_Running_Time"
|
|
|
|
|
echo "--------------------------------------------------"
|
|
|
|
|
for userid in `cat /tmp/long-running-processes.txt`
|
|
|
|
|
do
|
|
|
|
|
username=$(ps -u -p $userid | tail -1 | awk '{print $1}')
|
|
|
|
|
pruntime=$(ps -p $userid -o etime | tail -1)
|
|
|
|
|
ocmd=$(ps -p $userid | tail -1 | awk '{print $4}')
|
|
|
|
|
echo "$username $userid $ocmd $pruntime"
|
|
|
|
|
done | column -t
|
|
|
|
|
echo "--------------------------------------------------"
|
|
|
|
|
```
|
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
给 **”long-running-cpu-proc.sh“** 设置可执行**[Linux 文件权限][4]**。
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
# chmod +x /opt/scripts/long-running-cpu-proc.sh
|
|
|
|
|
```
|
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
运行此脚本时,你将获得类似以下的输出。
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
# sh /opt/scripts/long-running-cpu-proc.sh
|
|
|
|
|
|
|
|
|
|
----------------------------------------------------
|
|
|
|
|
UName PID CMD Process_Running_Time
|
|
|
|
|
----------------------------------------------------
|
|
|
|
|
daygeek 5214 Web 01:18:48
|
|
|
|
|
daygeek 5748 Web 01:08:20
|
|
|
|
|
daygeek 8043 inkscape 22:11
|
|
|
|
|
daygeek 5269 Web 01:18:31
|
|
|
|
|
daygeek 1712 Web 10:44:50
|
|
|
|
|
daygeek 5335 RDD 01:17:54
|
|
|
|
|
daygeek 1639 firefox 10:44:51
|
|
|
|
|
daygeek 7793 nautilus 24:14
|
|
|
|
|
daygeek 6301 Web 57:40
|
|
|
|
|
----------------------------------------------------
|
|
|
|
|
```
|
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
### 2)Bash 脚本检查高内存消耗进程在 Linux 上运行了多长时间
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
该脚本将帮助你确定最大的内存消耗进程在 Linux 上运行了多长时间。
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
# sh /opt/scripts/long-running-memory-proc.sh
|
|
|
|
|
|
|
|
|
|
#!/bin/bash
|
|
|
|
|
ps -eo pid,user,ppid,%mem,%cpu,cmd --sort=-%mem | head | tail -n +2 | awk '{print $1}' > /tmp/long-running-processes-1.txt
|
|
|
|
|
echo "--------------------------------------------------"
|
|
|
|
|
echo "UName PID CMD Process_Running_Time"
|
|
|
|
|
echo "--------------------------------------------------"
|
|
|
|
|
for userid in `cat /tmp/long-running-processes-1.txt`
|
|
|
|
|
do
|
|
|
|
|
username=$(ps -u -p $userid | tail -1 | awk '{print $1}')
|
|
|
|
|
pruntime=$(ps -p $userid -o etime | tail -1)
|
|
|
|
|
ocmd=$(ps -p $userid | tail -1 | awk '{print $4}')
|
|
|
|
|
echo "$username $userid $ocmd $pruntime"
|
|
|
|
|
done | column -t
|
|
|
|
|
echo "--------------------------------------------------"
|
|
|
|
|
```
|
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
给 **”long-running-memory-proc.sh“** 设置可执行 Linux 文件权限。
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
# chmod +x /opt/scripts/long-running-memory-proc.sh
|
|
|
|
|
```
|
|
|
|
|
|
2020-07-24 08:35:28 +08:00
|
|
|
|
运行此脚本时,你将获得类似以下的输出。
|
2020-01-07 00:55:40 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
# sh /opt/scripts/long-running-memory-proc.sh
|
|
|
|
|
|
|
|
|
|
----------------------------------------------------
|
|
|
|
|
UName PID CMD Process_Running_Time
|
|
|
|
|
----------------------------------------------------
|
|
|
|
|
daygeek 1639 firefox 10:44:56
|
|
|
|
|
daygeek 2997 Web 10:39:54
|
|
|
|
|
daygeek 5269 Web 01:18:37
|
|
|
|
|
daygeek 1712 Web 10:44:55
|
|
|
|
|
daygeek 8043 inkscape 22:17
|
|
|
|
|
daygeek 5214 Web 01:18:54
|
|
|
|
|
daygeek 1898 Web 10:44:48
|
|
|
|
|
daygeek 1129 Xorg 10:45:07
|
|
|
|
|
daygeek 6301 Web 57:45
|
|
|
|
|
----------------------------------------------------
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
via: https://www.2daygeek.com/bash-script-to-check-how-long-the-high-cpu-memory-consumption-processes-runs-on-linux/
|
|
|
|
|
|
|
|
|
|
作者:[Magesh Maruthamuthu][a]
|
|
|
|
|
选题:[lujun9972][b]
|
2020-07-24 08:35:28 +08:00
|
|
|
|
译者:[geekpi](https://github.com/geekpi)
|
2020-01-07 00:55:40 +08:00
|
|
|
|
校对:[校对者ID](https://github.com/校对者ID)
|
|
|
|
|
|
|
|
|
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
|
|
|
|
|
|
|
|
|
[a]: https://www.2daygeek.com/author/magesh/
|
|
|
|
|
[b]: https://github.com/lujun9972
|
|
|
|
|
[1]: https://www.2daygeek.com/how-to-find-high-cpu-consumption-processes-in-linux/
|
|
|
|
|
[2]: https://www.2daygeek.com/linux-find-top-memory-consuming-processes/
|
|
|
|
|
[3]: https://www.2daygeek.com/how-to-check-how-long-a-process-has-been-running-in-linux/
|
|
|
|
|
[4]: https://www.2daygeek.com/understanding-linux-file-permissions/
|