视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Laravel Cron 定时任务“跳坑”点
2020-11-03 23:10:28 责编:小采
文档


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

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

这个坑坑了工程师一个下午 ...

下载本文
显示全文
专题