Laravel 5.4 应用程序。 CACHE_DRIVER
设置为file
和QUEUE_DRIVER
设置为sync
在.env
.
当我运行php artisan cache:clear
时它说Cache cleared successfully
但我的 storage/framework/cache
中仍然有 236K 个文件目录。
对此感到沮丧,我还手动删除了 storage/framework/cache
下的所有文件/目录使用rm -rf *
从该目录。
现在,当我运行 art queue:restart
时我得到[ErrorException] file_put_contents(/var/www/vhosts/my-app.com/releases/28/storage/framework/cache/ee/2f/ee2f842aa7bb1f53ed<br/>
f3a2ed2c09a1807ffa6c90): failed to open stream: No such file or directory
所以,我手上有两个问题。首先是:为什么 Artisan 没有删除所有缓存文件?我如何安全地删除它们?第二个问题是:我如何从中恢复,以便 php artisan queue:restart
我没有出错吗?
更新:我突然想到,如果QUEUE_DRIVER
,我可能没有理由重新启动队列工作程序。设置为sync
,所以跳过该命令完全解决了我的一半问题。但仍然不确定如何正确删除那 236K 的缓存文件。
最佳答案
2020 年 1 月更新
似乎有一个简单的解决方案可以解决所有这些问题。使用这个答案https://serverfault.com/a/96349作为引用,您可以在父文件夹上设置 gid 位,以便在 ./storage/*
下创建的所有后续文件和文件夹正确组中的任何人都可以写入,无论是谁创建的;从而克服了组安全权限问题,如下所述。
这对我有用:
# Assumes all required users belong to the www-data group
sudo chgrp -R www-data /path/to/storage
sudo chmod g+s /path/to/storage
简短回答
使用sudo:sudo rm -r ./storage/framework/cache
长答案
确保写入缓存的所有进程都使用相同的用户(而不仅仅是属于同一组),因为事实证明 Laravel 使用 0755 的权限写入缓存文件,该权限限制对所有者的写入。
如果像我一样,您为每个用户使用不同的用户:
- PHP 进程
- Artisan CLI
- artisan 通过主管(工作)
您最终会得到属于不同用户的文件,并且其他用户无法写入或删除,即使它们属于所需的组(例如 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
& 运行 rm
是一个足够简单的解决方法;虽然它没有解决为什么文件被写为写保护的问题。
删除缓存后,Laravel 再次将缓存创建为写保护。这意味着它可能是一个错误并且需要有人向 Laravel 开发人员提交错误报告。由于解决方法很简单,我将把它留给其他人来做。
关于php - Laravel 5.4 - php artisan 缓存 :clear does not clear cache files when using 'file' cache driver,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45555783/