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

代碼最后有進行回車換行。

這個坑坑了工程師一個下午 …

? 版權聲明
THE END
喜歡就支持一下吧
點贊10 分享