通过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