Rumah > rangka kerja php > Laravel > Laravel Cron 定时任务“跳坑”点

Laravel Cron 定时任务“跳坑”点

藏色散人
Lepaskan: 2019-11-15 14:04:52
ke hadapan
3383 orang telah melayarinya

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

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

但是在实际使用的过程中,如果对 Linux 和 Cron 不熟悉,会遇到一些小坑,我们整理并记录了分享出来希望能帮助到大家。

坑1:环境变量

当Cron无法生效时,可能是Cron执行环境变量不正确引起的。

执行命令

env > /tmp/env.output
Salin selepas log masuk

打开/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
Salin selepas log masuk

坑2:Cron 执行用户导致 Laravel log 不可写

通过 crontab -e 命令创建的 Cron 是属于 root 用户,如果定时任务在实行时主动写入日志或者遇到异常未捕捉,会创建 root 权限的日志文件,最终会导致 php-fpm 的 www 账号无法写入。

因此需要在创建 cron 的时候指定用户

crontab -u www -e
Salin selepas log masuk

个人管理的系统中 php-fpm 执行用户都是 www,请根据自己的实际情况调整代码。

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

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

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

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

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

Atas ialah kandungan terperinci Laravel Cron 定时任务“跳坑”点. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:segmentfault.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan