Laravel 5.4 应用程序。 CACHE_DRIVER
is set to file
and QUEUE_DRIVER
is set to sync
in .env
.
当我运行 php artisan cache:clear
它说 Cache cleared successfully
但我的 storage/framework/cache
目录中仍然有236K的文件
对此感到沮丧,我还使用 rm -rf *
从该目录中手动删除了 storage/framework/cache
下的所有文件/目录。
现在,当我运行 art queue:restart
我得到 [ErrorException] file_put_contents(/var/www/vhosts/my-app.com/releases/28/storage/framework/cache/ee/2f/ee2f842aa7bb1f53ed
f3a2ed2c09a1807ffa6c90): failed to open stream: No such file or directory
所以,我手上有两个问题。首先是:为什么 Artisan 没有删除所有缓存文件?我如何安全地删除它们?第二个问题是:我如何从中恢复,以便 php artisan queue:restart
不会对我出错?
更新:我突然想到,如果 QUEUE_DRIVER
设置为 sync
,我可能没有理由重新启动队列工作程序,因此跳过该命令完全解决了我的一半问题。仍然不确定如何正确删除那些 236K 的缓存文件。
原文由 fronzee 发布,翻译遵循 CC BY-SA 4.0 许可协议
2020 年 1 月更新
似乎所有这些都有一个简单的解决方案。使用此答案 https://serverfault.com/a/96349 作为参考,您可以在父文件夹上设置 gid 位,以便在
./storage/*
下创建的所有后续文件和文件夹都可以被任何人写入正确的组,不管是谁创建的;从而克服如下所述的组安全许可问题。这对我有用:
简答
使用须藤:
sudo rm -r ./storage/framework/cache
长答案
确保写入缓存的所有进程都使用相同的用户(而不仅仅是属于同一组),因为事实证明,Laravel 写入缓存文件的权限类似于 0755,这限制了对所有者的写入。
如果像我一样,您对每个用户使用不同的用户:
您最终会得到属于不同用户的文件,即使它们属于所需的组(例如 www-data),其他用户也无法写入或删除这些文件。
希望有人能找到一种方法将 Larvel 中的新缓存文件权限设置为 0775 之类的东西。如果它只是从父级继承就好了。
边注
这对我来说也导致了
Cache::remember()
主管进程和 PHP 进程之间的问题,以至于我得到put_file_contents
错误,因为缓存文件无法被不同的写入用户。原答案
我遇到了同样的问题,在我的情况下,文件没有被删除,因为它们被写保护了。当我使用
rm -r ./storage/framework/cache
手动删除它们时,我收到警告rm: descend into write-protected directory 'cache/c5'?
。我不打算为缓存中的每个文件都键入 yes,所以我运行了与 sudo 相同的命令并且它运行顺利sudo rm -r ./storage/framework/cache
。这回答了关于为什么 Artisan 没有删除它们的问题
cache:clear
& runningrm
是一个足够简单的解决方法;尽管它没有解决为什么文件被写为写保护的问题。删除缓存后,Laravel 再次将缓存创建为写保护。这意味着它可能是一个错误,需要有人向 Laravel 开发人员提交错误报告。由于解决方法很简单,我会把它留给其他人去做。