shell awk 检查程序是否执行

张映 发表于 2015-10-20

分类目录: linux

标签:, ,

通过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"}}'


转载请注明
作者:海底苍鹰
地址:http://blog.51yip.com/linux/1774.html

1 条评论

  1. 小李李 留言

    为什么不能评论