在之前的部落格中,曾經寫了自動化測試程式的實現方法,現在開發人員需要知道被測試的進程(在此指運行在LINUX上的主進程的)在異常退出之前的進程的運行狀態,例如記憶體的使用率、CPU的使用率等。
現用shell指令碼實現指定進程的運行狀態。直接上代碼。
#!/bin/shecho "`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 $memInfotestPrg=""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=""doneecho "End $0---($pName,$myStatus,$testPrg)-------------------"if [ -z "$pName" ]; then ###發現測被測試程式異常退出後,停止測試程式 killall MyTester echo "stop TestProgram MyTester"fiecho "`date`"echo "---------------Current Status------------------"ps | grep -E "mainApp|SubApp" | grep -v grepecho ""
樣實現了每10s讀取一下進程的狀態,然後顯示出來,當發現進程存在並且狀態非Z(非殭屍)時,繼續監視,但是當測試程式執行完畢或是異常退出時,該指令碼也會退出監視迴圈,退出迴圈後,列印出指定進程的狀態。