Laravel Cron 定时任务“跳坑”点

Laravel 中执行定时任务是经过 cron 来实现,官网文档中就是简单一句 + 一行Cron 代码php

* * * * * php /path-to-your-project/artisan schedule:run >> /dev/null 2>&1

可是在实际使用的过程当中,若是对 Linux 和 Cron 不熟悉,会遇到一些小坑,咱们整理并记录了分享出来但愿能帮助到你们。mysql

坑1:环境变量

Cron没法生效时,多是Cron执行环境变量不正确引发的。sql

执行命令

env > /tmp/env.output

打开/tmp/env.output文件,将PATH字段整行添加至corntab文件顶部,corntab文件在/var/spool/cron目录下php7

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-fpmwww 帐号没法写入。memcached

所以须要在建立 cron 的时候指定用户php-fpm

crontab -u www -e
我的管理的系统中 php-fpm 执行用户都是 www,请根据本身的实际状况调整代码。

坑3:cron 内容最后一行未回车

解决上述两点问题后,若是仍然发现 cron 不执行,请确认spa

* * * * * php /path-to-your-project/artisan schedule:run >> /dev/null 2>&1

代码最后有进行回车换行。日志

这个坑坑了工程师一个下午 : (code

讨论交流

联系咱们

相关文章
相关标签/搜索