實(shí)用腳本:檢查高CPU/內(nèi)存消耗進(jìn)程
過(guò)去,我們寫(xiě)了三篇不同的文章來(lái)使用 Linux 命令來(lái)識(shí)別這些進(jìn)程。
你可以通過(guò)下面相關(guān)的 URL 立即訪問(wèn):
- 如何在 Linux 中找出 CPU 占用高的進(jìn)程
- 如何在 Linux 中找出內(nèi)存消耗最大的進(jìn)程
- 在 Linux 中如何查找一個(gè)命令或進(jìn)程的執(zhí)行時(shí)間
本教程中包含兩個(gè)腳本,它們可以幫助你確定 Linux 上高 CPU/內(nèi)存消耗進(jìn)程的運(yùn)行時(shí)間。
該腳本將顯示進(jìn)程 ID、進(jìn)程的所有者、進(jìn)程的名稱以及進(jìn)程的運(yùn)行時(shí)間。這將幫助你確定哪些(必須事先完成)作業(yè)正在超時(shí)運(yùn)行。這可以使用 ps 命令來(lái)實(shí)現(xiàn)。
什么是 ps 命令
ps 是進(jìn)程狀態(tài),它顯示有關(guān)系統(tǒng)上活動(dòng)/正在運(yùn)行的進(jìn)程的信息。
它提供了當(dāng)前進(jìn)程的快照以及詳細(xì)信息,例如用戶名、用戶 ID、CPU 使用率、內(nèi)存使用率、進(jìn)程開(kāi)始日期和時(shí)間等。
1)檢查高 CPU 消耗進(jìn)程在 Linux 上運(yùn)行了多長(zhǎng)時(shí)間的 Bash 腳本
該腳本將幫助你確定高 CPU 消耗進(jìn)程在 Linux 上運(yùn)行了多長(zhǎng)時(shí)間。
# vi /opt/scripts/long-running-cpu-proc.sh#!/bin/bashps -eo pid,user,ppid,%mem,%cpu,cmd --sort=-%cpu | head | tail -n +2 | awk '{print $1}' > /tmp/long-running-processes.txtecho "--------------------------------------------------"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í),你將獲得類(lèi)似以下的輸出:
# sh /opt/scripts/long-running-cpu-proc.sh----------------------------------------------------UName PID CMD Process_Running_Time----------------------------------------------------daygeek 5214 Web 01:18:48daygeek 5748 Web 01:08:20daygeek 8043 inkscape 22:11daygeek 5269 Web 01:18:31daygeek 1712 Web 10:44:50daygeek 5335 RDD 01:17:54daygeek 1639 firefox 10:44:51daygeek 7793 nautilus 24:14daygeek 6301 Web 57:40----------------------------------------------------
2)檢查高內(nèi)存消耗進(jìn)程在 Linux 上運(yùn)行了多長(zhǎng)時(shí)間的 Bash 腳本
該腳本將幫助你確定最大的內(nèi)存消耗進(jìn)程在 Linux 上運(yùn)行了多長(zhǎng)時(shí)間。
# sh /opt/scripts/long-running-memory-proc.sh#!/bin/bashps -eo pid,user,ppid,%mem,%cpu,cmd --sort=-%mem | head | tail -n +2 | awk '{print $1}' > /tmp/long-running-processes-1.txtecho "--------------------------------------------------"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í),你將獲得類(lèi)似以下的輸出:
# sh /opt/scripts/long-running-memory-proc.sh----------------------------------------------------UName PID CMD Process_Running_Time----------------------------------------------------daygeek 1639 firefox 10:44:56daygeek 2997 Web 10:39:54daygeek 5269 Web 01:18:37daygeek 1712 Web 10:44:55daygeek 8043 inkscape 22:17daygeek 5214 Web 01:18:54daygeek 1898 Web 10:44:48daygeek 1129 Xorg 10:45:07daygeek 6301 Web 57:45----------------------------------------------------
























