我有一个执行PHP脚本的cron作业. cron设置为每分钟运行一次,这仅用于测试目的.它正在执行的PHP脚本旨在将用户上传到服务器的视频转换为Flash格式(例如…… .flv).当通过命令行手动执行脚本时脚本执行正常,但是当通过cron执行它时启动正常,但一分钟后它就会停止.
似乎当执行下一个cron时,它“杀死”最后一个cron执行.
我添加了以下PHP函数:
ignore_user_abort(true);
希望它不会中止最后一次执行,我测试将cron设置为每5分钟运行一次,这很好,但是视频的转换可能需要5分钟以上,所以我需要弄清楚为什么它停止时另一个cron是执行.
任何帮助,将不胜感激.
谢谢!
编辑:
我的cron看起来像:
*/1 * * * * php /path_to_file/convert.php
解决方法:
我不认为cron会杀死任何进程.但是,cron并不适合长时间运行的进程.这里可能发生的事情是,当脚本执行多次时,你的脚本会全身踩踏.例如,两个PHP进程可能都在尝试同时写入同一个文件.
首先,确保您不仅要查看php错误日志,还要尝试从PHP文件本身捕获输出.例如:
*/1 * * * * * php /path/to/convert.php & >> /var/log/convert.log
您还可以使用简单的锁定文件来确保convert.php不会多次执行.就像是:
if (file_exists('/tmp/convert.lock')) {
exit();
}
touch('/tmp/convert.lock');
// convert here
unlink('/tmp/convert.lock');
标签:php,scheduled-tasks,cron 来源: https://codeday.me/bug/20191004/1853222.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。