在之前的博客中,曾經(jīng)寫了自動(dòng)化測(cè)試程序的實(shí)現(xiàn)方法,現(xiàn)在開發(fā)者需要知道被測(cè)試的進(jìn)程(在此指運(yùn)行在LINUX上的主進(jìn)程的)在異常退出之前的進(jìn)程的運(yùn)行狀態(tài),例如內(nèi)存的使用率、CPU的使用率等。
現(xiàn)用shell腳本實(shí)現(xiàn)指定進(jìn)程的運(yùn)行狀態(tài)。直接上代碼。
#!/bin/shecho "`date`"echo "Start $0---------"echo ""#每十秒監(jiān)視一下sec=10#取得指定進(jìn)程名為mainAPP,內(nèi)存的使用率,進(jìn)程運(yùn)行狀態(tài),進(jìn)程名稱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        ###發(fā)現(xiàn)測(cè)被測(cè)試程序異常退出后,停止測(cè)試程序    killall MyTester    echo "stop TestProgram MyTester"fiecho "`date`"echo "---------------Current Status------------------"ps | grep -E "mainApp|SubApp" | grep -v grepecho ""樣實(shí)現(xiàn)了每10s讀取一下進(jìn)程的狀態(tài),然后顯示出來,當(dāng)發(fā)現(xiàn)進(jìn)程存在并且狀態(tài)非Z(非僵尸)時(shí),繼續(xù)監(jiān)視,但是當(dāng)測(cè)試程序執(zhí)行完畢或是異常退出時(shí),該腳本也會(huì)退出監(jiān)視循環(huán),退出循環(huán)后,打印出指定進(jìn)程的狀態(tài)。
新聞熱點(diǎn)
疑難解答
網(wǎng)友關(guān)注