首頁  >  問答  >  主體

Docker 多容器协作共享volume的权限问题

先上个结构图

然后现在的情况是访问访问本地8080端口来访问tengine容器的80端口
http://x.x.x.x:8080/index.html
可以正常访问
http://x.x.x.x:8080/index.php
phpfpm容器显示日志:

172.17.0.3 -  12/Nov/2015:08:57:00 +0000 "GET /index.php" 404
172.17.0.3 -  12/Nov/2015:08:57:00 +0000 "GET /index.php" 404
172.17.0.3 -  12/Nov/2015:08:57:00 +0000 "GET /index.php" 404

显示404.无法访问到页面,那么我想可能是权限问题。
【进入tengine容器

【进入phpfpm容器

我是直接用了php:5.5.30-fpm的image来把phpfpm容器跑起来
phpfpm容器/usr/local/etc/php-fpm.conf文件我看了下

user = www-data
group = www-data

关键的问题来了:
我在phpfpm容器中用chown -R www-data:www-data /data/sites命令后,
/data/sites下所有文件拥有者依然是staff。
1、为啥无法更改volume锁挂在目录的拥有者,是需要构建images的时候,改权限,然后再挂载?
2、staff是个什么鬼?

阿神阿神2707 天前747

全部回覆(3)我來回復

  • 巴扎黑

    巴扎黑2017-04-24 09:11:26

    volume的權限在於主機是怎麼給的,如果你想要給phpfpm文件夹www-data:www-data权限,在你的主机挂载目录执行chown -R www-data:www-data /data/sites即可。

    回覆
    0
  • 大家讲道理

    大家讲道理2017-04-24 09:11:26

    我也遇到相同的問題,請問樓主解決了嗎

    更新

    我剛剛解決了在 MAC 環境下,無法更改 volume 目錄的問題

    BTW 我是用 dockerfile build 的

    在 phpfpm 容器的 Dockerfile 加上以下兩行

    RUN usermod -u 1000 www-data
    RUN usermod -G staff www-data

    就可以解決了

    相關 issue 的討論

    回覆
    0
  • 迷茫

    迷茫2017-04-24 09:11:26

    之前也遇到了,是透過掛載時加權限解決的。

    回覆
    0
  • 取消回覆