我有一个运行以下内容的docker-compose.yml文件(创建名为mmm / nginx的图像):
web:
image: mmm/nginx
ports:
- "80:80"
volumes:
- ./var:/var/www
- ./etc/nginx/sites-enabled:/etc/nginx/sites-enabled/
links:
- php
- db
php:
image: rossriley/php56-fpm
volumes:
- ./var:/var/www
- ./etc/php5/php-fpm.conf:/etc/php5/fpm/php-fpm.conf
links:
- db
db:
image: sameersbn/mysql
ports:
- "3306:3306"
volumes:
- /var/lib/mysql
environment:
- DB_NAME=tables
- DB_USER=table
- DB_PASS=pass
它可以很好地提供存储在/var/www
当它尝试写入日志并尝试写入会话文件时,会发生此问题。虽然确实创建了文件,但却无法编写文件。
storage
及其嵌套目录的文件夹的权限设置为777
。
为了让laravel写给他们,我必须$ chmod 777 <.log|sessionfile>
并且它很好用。显然,这不是开发方式,因为我需要定期开始新会话并每天创建新日志。
如何为laravel和docker containers提供写入他们创建的文件的权限?
更新 这就是laravel的日志所说的:
local.ERROR: exception 'ErrorException' with message 'file_put_contents(/var/www/com.mtrinteractive.sandbox.form/storage/framework/sessions/e0117b8ca17af9c19572ddb305a272b4c22bd18d): failed to open stream: Permission denied' in /var/www/com.mtrinteractive.sandbox.form/vendor/laravel/framework/src/Illuminate/Filesystem/Filesystem.php:81
更新#2
这是项目目录:
更新#3
以下是项目的权限和所有者:
答案 0 :(得分:2)
我不知道这是否有帮助,但是如果你使用Dockerfile就可以添加
运行usermod -u 1000 nginx
或者如果你使用Apache你可以分。 nginx for apache。
这似乎只是OS X的一个问题,问题实际上与VirtualBox有关,而与Docker没有直接关系。我在Docker v1.9.x中遇到过这个问题,现在再次使用v1.10.3。这次我无法用上述解决方案解决它,但能够通过将我的缓存写入数据库来解决它。在这种情况下,它是MySQL / MariaDB,但很容易就是memcache或redis。
奇怪的是,创建日志文件并写入它们并不是一个问题,即使卷是单独安装的,而是源自同一个文件夹&#39; / Users&#39;我的Mac。