本教程中包含兩個腳本,它們可以幫助你確定 linux 上高 CPU/內(nèi)存消耗進(jìn)程的運(yùn)行時間。
• 來源:linux.cn • 作者:Magesh Maruthamuthu • 譯者:geekpi •
(本文字?jǐn)?shù):3589,閱讀時長大約:4 分鐘)
過去,我們寫了三篇不同的文章來使用 Linux 命令來識別這些進(jìn)程。
你可以通過下面相關(guān)的 URL 立即訪問:
- 如何在 Linux 中找出 CPU 占用高的進(jìn)程
- 如何在 Linux 中找出內(nèi)存消耗最大的進(jìn)程
- 在 Linux 中如何查找一個命令或進(jìn)程的執(zhí)行時間
本教程中包含兩個腳本,它們可以幫助你確定 Linux 上高 CPU/內(nèi)存消耗進(jìn)程的運(yùn)行時間。
該腳本將顯示進(jìn)程 ID、進(jìn)程的所有者、進(jìn)程的名稱以及進(jìn)程的運(yùn)行時間。這將幫助你確定哪些(必須事先完成)作業(yè)正在超時運(yùn)行。這可以使用 ps 命令來實(shí)現(xiàn)。
什么是 ps 命令
ps 是 進(jìn)程狀態(tài)(processes status),它顯示有關(guān)系統(tǒng)上活動/正在運(yùn)行的進(jìn)程的信息。
它提供了當(dāng)前進(jìn)程的快照以及詳細(xì)信息,例如用戶名、用戶 ID、CPU 使用率、內(nèi)存使用率、進(jìn)程開始日期和時間等。
1)檢查高 CPU 消耗進(jìn)程在 Linux 上運(yùn)行了多長時間的 Bash 腳本
該腳本將幫助你確定高 CPU 消耗進(jìn)程在 Linux 上運(yùn)行了多長時間。
# 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`
dousername=$(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 -techo "--------------------------------------------------"
給 long-running-cpu-proc.sh 設(shè)置可執(zhí)行的 Linux 文件權(quán)限 。
# chmod +x /opt/scripts/long-running-cpu-proc.sh
運(yùn)行此腳本時,你將獲得類似以下的輸出:
# 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
----------------------------------------------------
2)檢查高內(nèi)存消耗進(jìn)程在 Linux 上運(yùn)行了多長時間的 Bash 腳本
該腳本將幫助你確定最大的內(nèi)存消耗進(jìn)程在 Linux 上運(yùn)行了多長時間。
# 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`
dousername=$(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 -techo "--------------------------------------------------"
給 long-running-memory-proc.sh 設(shè)置可執(zhí)行的 Linux 文件權(quán)限。
# chmod +x /opt/scripts/long-running-memory-proc.sh
運(yùn)行此腳本時,你將獲得類似以下的輸出:
# 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: www.2daygeek.com
作者: Magesh Maruthamuthu 選題: lujun9972 譯者: geekpi 校對: 校對者ID
本文由 LCTT 原創(chuàng)編譯, Linux中國 榮譽(yù)推出