从docker nginx / php-fpm安装在本地卷(Mac)上的Laravel无法写入会话文件

时间:2016-02-09 21:34:38

标签: php laravel session permissions docker

我有一个运行以下内容的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

这是项目目录:

enter image description here

更新#3

以下是项目的权限和所有者:

enter image description here

enter image description here

enter image description here

1 个答案:

答案 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。