shell awk 检查程序是否执行

2016/12/04

通过shell结合awk可以很好判断某一进程是不是运行,或者某一程序文件是否被执行,下面以php为例来说明一下。

定义一个crontab,每一分钟执行一次,时间间隔为一分钟,可能下一次执行的时候,上次还没有执行完,所以我们要做一下判断。

1.test.php在运行的情况,查看进程

$ ps -ef |grep test.php  
root     29884 29881  0 10:48 ?        00:00:00 awk NR==1{\?if ($8 == "grep"){\?system("cd /home/test/cron && php test.php");\?}else{\?print "running";\?}\?}  
root     29888 29884  0 10:48 ?        00:00:00 sh -c cd /home/test/cron && php test.php  
root     29889 29888  1 10:48 ?        00:00:00 php test.php  
root     30265  7620  0 10:48 pts/0    00:00:00 grep test.php  

2.test.php不在运行的情况,如下

$ ps -ef |grep test.php  
root     30265  7620  0 10:48 pts/0    00:00:00 grep test.php  

3.test.sh脚本如下

$ cat test.sh  
ps -ef|grep test.php | awk 'NR==1{\
if ($8 == "grep"){\
system("cd /home/test/cron && php test.php");\
}else{\
print "running";\
}\
}'

exit
ps -ef grep test.php,当第8列等于grep的时候,test.php是没有运行的,system调用php执行test.php,反之在运行。

4.实际运行的情况

执行test.sh后,一天差不多,会出现一次这样的情况,

$ ps -ef |grep test.php  
root      8043  8040  0 09:33 ?        00:00:00 awk NR==1{\?if ($8 == "grep"){\?system("cd /home/test/cron && php test.php");\?}else{\?print "running";\?}\?}  
root      8044  8043  0 09:33 ?        00:00:00 sh -c cd /home/test/cron && php test.php  
root      8045  8044  0 09:33 ?        00:00:00 php test.php  
root     18952 18947  0 Oct14 ?        00:00:00 awk NR==1{\?if ($8 == "grep"){\?system("cd /home/test/cron && php test.php");\?}else{\?print "running";\?}\?}  
root     18954 18952  0 Oct14 ?        00:00:00 sh -c cd /home/test/cron && php test.php  
root     18955 18954  0 Oct14 ?        00:00:01 php test.php  
root     23430 23410  0 10:32 pts/0    00:00:00 grep test.php  

然后导致php程序卡死,一直没有搞清楚,为什么会这样。

5.解决办法

$ cat t.sh  
t=0  
eval $(ps -ef |grep test.php |awk 'BEGIN {t = 0;}{if ( $8 == "php"){t++;}}END{print "t="t;}');  

if [ $t -gt 1 ]  
then  
 kill -9 $(ps -ef |grep test.php |awk '{L[NR]=$2;a[NR]=$8;}END{for (i=1;i<=NR;i++){if(a[i] != "grep"){print L[i];}}}');  
else  
 echo "$t no killing";  
fi  

exit;  

t.sh的意思,每隔一段时间检查一下,test.php正在被执行的次数,如果大于1,就强行结束掉,所有根test.php有关的进程。

6.awk查看,倒排序查看,服务器各类进程数

$ ps -ef| awk '{a[$8]++}END{for(i in a){print i,a[i] | "sort -r -k 2"}}'  

«««< HEAD