执行 crontab 的计划任务

时间:2022-06-30 18:09:11

新建了一个 Laravel 的计划任务,配置好 crontab

* * * * * php /www/sunzhongwei/artisan schedule:run >> /dev/null 2>&1

同时,将当前登录用户,添加到了 www-data 的用户组,以防止无法访问 storage/logs 下的日志文件。

但是,执行了一段时间,导致 web 请求报错

file_put_contents(/www/sunzhongwei/storage/framework/cache/data/f1/6c/f16xxxx56b65501434d05bf1fc20c9fc8f9): failed to open stream: No such file or directo
ry

通过 ls -la 查看,可以发现该文件属于当前登录用户,而不是 www-data,用户组也不是 www-data 所属的用户组。

那就说明解决方法只有一个,就是以 www-data 的身份执行 laravel crontab 的计划任务。

对应的命令是

sudo crontab -u www-data -e

然后把上面的计划任务配置剪切过来就可以了。

测试环境

Ubuntu 16.04 Server

参考

https://askubuntu.com/questions/189189/how-to-run-crontab-as-userwww-data