Linux下實現腳本監測特定進程占用內存情況


Linux系統下,我們可以利用以下命令來獲取特定進程的運行情況: 

cat /proc/$PID/status

其中PID是具體的進程號,這個命令打印出/proc/特定進程/status文件的內容,信息比較多,包含了物理內存/虛擬內存的使用狀況,監控進程是否有內存泄露的問題,一般查看進程占用物理內存的情況:

VmRSS: xxxkB

可以采用grep命令過濾出我們需要的信息:

cat /proc/$PID/status | grep RSS >> "$LOG" #過濾包含RSS的行,並且重定向到參數LOG表示的文件

由於PID號需要通過進程名獲取,同樣使用grep命令過濾出我們指定進程的進程號:

ps | grep $PROCESS | grep -v 'grep' | awk '{print $1;}'#$PROCESS表示進程名字

  

再設置一個循環,每十秒獲取一次信息並寫入指定文件,完整的腳本如下:.

 1 #!/bin/bash
 2 
 3 PROCESS=進程名
 4 LOG="/mnt/memlog.txt"
 5 
 6 sleep 10
 7 
 8 #刪除上次的監控文件
 9 if [ -f "$LOG" ];then 
10     rm "$LOG"
11 fi
12 
13 #過濾出需要的進程ID
14 PID=$(ps | grep $PROCESS | grep -v 'grep' | awk '{print $1;}')
15 
16 while [ "$PID" != "" ]    
17 do
18     cat /proc/$PID/status | grep RSS >> "$LOG"#過濾出VmRSS行
19     sleep 5
20     PID=$(ps | grep $PROCESS | grep -v 'grep' | awk '{print $1;}')
21 done

 

范例2

shell腳本1.

 1 #!/bin/bash
 2 pid=$1  #獲取進程pid
 3 echo $pid
 4 interval=1  #設置采集間隔
 5 while true
 6 do
 7     echo $(date +"%y-%m-%d %H:%M:%S") >> proc_memlog.txt
 8     cat  /proc/$pid/status|grep -e VmRSS >> proc_memlog.txt    #獲取內存占用
 9     cpu=`top -n 1 -p $pid|tail -2|head -1|awk '{ssd=NF-4} {print $ssd}'`    #獲取cpu占用
10     echo "Cpu: " $cpu >> proc_memlog.txt
11     echo $blank >> proc_memlog.txt
12     sleep $interval
13 done

 

調用方式

$ sh shellName.sh [pid]
#exp:
sh monitor.sh 1234

  

腳本1-meminfo.sh:

 1 #!/bin/bash
 2 interval=60 
 3 if [ "$1" != "" ]
 4 then
 5 interval=$1
 6 fi
 7 echo "檢查時間間隔(單位秒):"$interval
 8 datetime=`date +'%Y%m%d'`
 9 echo""> /home/info/info-$datetime
10 while :
11 do
12 echo `date +'%Y%m%d %H:%M:%S'` >> /home/info/info-$datetime
13 cat /proc/meminfo | grep -E 'MemTotal|MemFree|Cached' |grep -v SwapCached|xargs >>/home/info/info-$datetime 
14 top -b -d 1 -n 1 |grep -E "PID.*USER|load|Cpu|Data" >> /home/info/info-$datetime
15 sleep $interval
16 echo "-------------------------------------" >> /home/info/info-$datetime
17 done

注釋:

第2-5行:設定一個內存監測時間間隔,如果用戶輸入,則為用戶輸入的值,如果用戶沒有輸入,則默認為60s監測一次($1為我們執行程序是給程序的第一個參數)
第8行:datetime=date +'%Y%m%d' 通過date命令獲取系統時間,並賦給datetime。變量date命令格式:date [選項]… [+格式]。
注意:一定要加反引號(),反引號在Linux中起着命令替換的作用。寫成單引號和雙引號會把命令當成字符串輸出的喲!

 

第13行:首先查看meminfo文件中的內容,通過管道傳遞給grep命令,通過-E選項篩選出包含MemTotal或MemFree或Cached的內容(grep -E 選項可以用來擴展選項為正則表達式),並傳遞給下一個grep命令,通過-v選項排除掉包含SwapCached的內容,最后通過xargs將內容輸出到文件(xargs將多行變成了單行,見下圖)。

 

第14行:通過top查看內存使用情況,並通過grep過濾后輸出到文件

 

運行腳本:./meminfo.sh [args1]
最后輸出結果:cat /home/info/info-20170629

 

http://www.cnblogs.com/franjia/p/4384362.html
http://man.linuxde.net/xargs

腳本2

這個程序只是監測了top中的RES值,輸出簡單,並且可以在內存不在變化時自動停止監測(不過這個也有弊端,因為有些程序不是一直穩定增長的,很可能穩定一下,又增長了,這時候程序就停了)。.

同時會打屏輸出:

#截取top的內存使用數
#如果文件存在,重命名
if [ -a memory.txt ]
then
    mv memory.txt memory_at_`date +%H:%M:%S`.txt
fi
#如果沒有輸入參數,默認60s檢查一次
if [ $# -eq 0 ]
then
    DREAM=60
else
    DREAM=$1
fi
echo "檢查內存時間間隔(秒):${DREAM}"
#當前內存數
RES_NOW=2
#上一次內存數
RES_BEF=1
#一致時退出
while [ $RES_NOW -ne $RES_BEF ]
do
    RES_BEF=$RES_NOW
    #取現在內存
    RES_NOW=$(top -d 1 -n 1|grep 'DataAccessEngin'|cut -d " " -f 14)
    TIME=`date +'%y%m%d %H:%M:%S'`
    #輸出
    echo "${TIME}進程使用內存數=[$RES_NOW]"
    echo "${TIME}  ${RES_NOW}">>memory.txt
    sleep $DREAM
done

echo "結束"

輸出結果:



同時會打屏輸出:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM