欢迎您访问365答案网,请分享给你的朋友!
生活常识 学习资料

crontab定时任务--踩坑记录

时间:2023-06-23

crontab 默认是使用 /bin/sh 来执行命令,然后这个导致了我的脚本程序出了问题
项目中,我的一个php脚本是一直在跑的,然后每天会自动停一次,为了保证脚本的持续运行,我给该脚本加入cron定时任务,设计的是每一分钟执行一次,并在脚本中检测当前运行该脚本的进程数,如果进程数 > 1, 则停止,这样保证了系统中始终只有一个运行这个脚本的进程,进程检测命令如下:
'ps ax|grep '.basename(__FILE__).' |grep -vE "grep|vim|bash" |wc -l'
然后 cron 中配置如下:
* * * * * php /var/www/script/test.php >> /var/www/log/test.log
理论上第一次运行时,进程检测命令应该返回1,然后通过检测,进入持续运行。之后cron拉起的脚本在进程检测时应该返回2,检测不通过,停止运行。
但,恶心的是:第一次运行时,进程检测命令就返回了2,然后我的脚本一次处于停止状态。
google了一圈,最后发现crontab 默认是使用 /bin/sh 来执行命令,相当于执行了/bin/sh -c ' php /var/www/script/test.php >> /var/www/log/test.log'
此时,会产生两个进程。。。

解决方法:使用"/bin/bash"来执行,就可以。修改cron 中配置如下:
* * * * * /bin/bash -c ' php /var/www/script/test.php >> /var/www/log/test.log'
问题解决!!!

注:看网上说,如果crond程序起了多个,也会产生“执行一次脚本命令,产生多个进程的问题”,特在此提醒,希望对大家定位问题有所帮助。。。

Copyright © 2016-2020 www.365daan.com All Rights Reserved. 365答案网 版权所有 备案号:

部分内容来自互联网,版权归原作者所有,如有冒犯请联系我们,我们将在三个工作时内妥善处理。