這篇文章主要介紹了Shell指令碼實現監視指定進程的運行狀態,本文直接給出指令碼代碼,需要的朋友可以參考下
在之前的部落格中,曾經寫了自動化測試程式的實現方法,現在開發人員需要知道被測試的進程(在此指運行在LINUX上的主進程的)在異常退出之前的進程的運行狀態,例如記憶體的使用率、CPU的使用率等。
現用shell指令碼實現指定進程的運行狀態。直接上代碼。
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 |
#!/bin/sh echo "`date`" echo "Start $0---------" echo "" #每十秒監視一下 sec=10 #取得指定進程名為mainAPP,記憶體的使用率,進程運行狀態,進程名稱 eval $(ps | grep "mainApp" | grep -v grep | awk {'printf("memInfo=%s;myStatus=%s;pName=%s",$3,$4,$5)'}) echo $pName $myStatus $memInfo testPrg="" while [ -n "$pName" -a "$myStatus" != "Z" ] do echo "----------`date`---------------------" echo $pName $myStatus $memInfo sleep $sec ####You must initialize them again!!!!! pName="" myStatus="" memInfo="" eval $(ps | grep "mainApp" | grep -v grep | awk {'printf("memInfo=%s;myStatus=%s;pName=%s",$3,$4,$5)'}) testPrg=`ps | grep "MyTester" | grep -v grep | awk '{print $0}'` if [ -z "$testPrg" ]; then break fi ##注意一定要再次初始化為空白 testPrg="" done echo "End $0---($pName,$myStatus,$testPrg)-------------------" if [ -z "$pName" ]; then ###發現測被測試程式異常退出後,停止測試程式 killall MyTester echo "stop TestProgram MyTester" fi echo "`date`" echo "---------------Current Status------------------" ps | grep -E "mainApp|SubApp" | grep -v grep echo "" |
樣實現了每10s讀取一下進程的狀態,然後顯示出來,當發現進程存在並且狀態非Z(非殭屍)時,繼續監視,但是當測試程式執行完畢或是異常退出時,該指令碼也會退出監視迴圈,退出迴圈後,列印出指定進程的狀態。