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-fpmwww 账号无法写入。

因此需要在创建 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年前 自动加精
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 17
php炎黄

刚好在弄这个定时任务,十分感谢。还有可以设置每秒执行吗 我看 laravel 文档最快也是每分钟一次

6年前 评论

@php 炎黄 每分钟执行一次,在脚本里在执行 60 次不就可以了

6年前 评论

有可能 www 的用户目录不存在,需要手动去 home 目录创建,然后赋予 www 的权限.
我就是在这里被深深的坑过,:sob: , 最后去翻 crontab 的日志才发现的

6年前 评论

找到 PHP 可执行文件绝对路径,也可以搞定环境变量问题,如果多个 PHP 版本共存或者说 PHP 可执行路径没加入 PATH 环境变量,更适用

[.... ~]# whereis php
php: /usr/bin/php /etc/php.ini /etc/php.d /usr/lib64/php /usr/include/php /usr/share/php /usr/share/man/man1/php.1.gz

执行命令

/usr/bin/php /path-to-your-project/artisan ...
6年前 评论

@php 炎黄 什么脚本要每秒执行啊

6年前 评论

请问下最后一行一定要加回车么,这是为什么呢?

6年前 评论

@键盘侠 不是特别懂 Linux,在我们的 centos7 64 位系统上,我们发现如果不换行的话, cron 不会执行,也不会有任何错误提示。

就是因为这样,工程师找了整整一个下午。

6年前 评论
城-北京

不错

6年前 评论

您好,请问设置每分钟执行一次会不会由于这次运行还没结束下一次运行又来了,长久下去,最后导致系统崩溃

6年前 评论

@troublesen withoutOverlapping 这个方法应该能做到合理限制

6年前 评论

我真的十分感谢,我想打赏你。

5年前 评论
          • php /path-to-your-project/artisan schedule:run >> /dev/null 2>&1
            我是手动添加到 cron 的文件里的,我是阿里的 centos7,按道理来说这个不是可以自动添加到 cron 里面吗?
5年前 评论
foobar

:thumbsup:

5年前 评论
xin6841414

碰到 log 没权限问题,有帮助 感谢

5年前 评论

file 查看自己 php-fpm 运行用户

5年前 评论