Laravel Cron 定时任务 “跳坑” 点
Laravel 中执行定时任务是通过 cron 来实现,官网文档中就是简单一句 + 一行Cron 代码
* * * * * php /path-to-your-project/artisan schedule:run >> /dev/null 2>&1
但是在实际使用的过程中,如果对 Linux 和 Cron 不熟悉,会遇到一些小坑,我们整理并记录了分享出来希望能帮助到大家。
坑1:环境变量
当Cron
无法生效时,可能是Cron
执行环境变量不正确引起的。
执行命令
env > /tmp/env.output
打开/tmp/env.output
文件,将PATH
字段整行添加至corntab
文件顶部,corntab
文件在/var/spool/cron
目录下
crontab
文件示例
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/opt/mysql/bin:/opt/php7/bin:/opt/memcached/bin:/root/bin
* * * * * php /path-to-your-project/artisan schedule:run >> /dev/null 2>&1
坑2:Cron 执行用户导致 Laravel log 不可写
通过 crontab -e
命令创建的 Cron
是属于 root
用户,如果定时任务在实行时主动写入日志或者遇到异常未捕捉,会创建 root 权限的日志文件,最终会导致 php-fpm
的 www
账号无法写入。
因此需要在创建 cron 的时候指定用户
crontab -u www -e
个人管理的系统中 php-fpm 执行用户都是 www,请根据自己的实际情况调整代码。
坑3:cron 内容最后一行未回车
解决上述两点问题后,如果仍然发现 cron 不执行,请确认
* * * * * php /path-to-your-project/artisan schedule:run >> /dev/null 2>&1
代码最后有进行回车换行。
这个坑坑了工程师一个下午 : (
本作品采用《CC 协议》,转载必须注明作者和本文链接
本帖由系统于 6年前 自动加精
刚好在弄这个定时任务,十分感谢.还有可以设置每秒执行吗 我看laravel文档最快也是每分钟一次
@php炎黄 每分钟执行一次,在脚本里在执行60次不就可以了
@php炎黄 https://blog.csdn.net/fdipzone/article/det... 看这里
有可能
www
的用户目录不存在, 需要手动去home
目录创建, 然后赋予www
的权限.我就是在这里被深深的坑过, :sob: , 最后去翻
crontab
的日志才发现的找到PHP可执行文件绝对路径,也可以搞定环境变量问题,如果多个PHP版本共存或者说PHP可执行路径没加入
PATH
环境变量,更适用执行命令
@php炎黄 什么脚本要每秒执行啊
请问下最后一行一定要加回车么,这是为什么呢?
@键盘侠 不是特别懂 Linux,在我们的centos7 64 位系统上,我们发现如果不换行的话, cron 不会执行,也不会有任何错误提示。
就是因为这样,工程师找了整整一个下午。
@shjchen 那也是很厉害了
不错
您好,请问设置每分钟执行一次会不会由于这次运行还没结束下一次运行又来了,长久下去,最后导致系统崩溃
@troublesen withoutOverlapping 这个方法应该能做到合理限制
我真的十分感谢,我想打赏你。
我是手动添加到cron的文件里的,我是阿里的centos7,按道理来说这个不是可以自动添加到cron里面吗?
:+1:
碰到log没权限问题,有帮助 感谢
php-fpm
运行用户