Docker 构建的PHP-FPM+NGINX+MYSQL开发环境,脚本写入数据权限问题

正常情况下,容器内部创建的文件目录写入权限是没问题的,并且是以root用户写入的。因为 Docker 引擎在宿主主机上是以root 权限运行的,但当 你 将 脚本 执行目录 挂载到 宿主 主机 的目录,由于与 宿主 主机当前登录的用户存在差异(宿主主机通常以非root用户登录),会导致脚本执行 写入 数据操作出现异常。

此时,我们将启用 docker run 命令的 -u 参数,他的值为 user:group 或者 uid:gid

在本例中,我们将 -u 参数的值 设置为 宿主主机当前登录用户的 用户名和组名 或者 用户id和用户组id

docker run -d --name php-fpm -u 1001:1001 -v $PWD/www:/var/www/html php:7-fpm

我的 -u 参数值 为 1001:1001

如何查找 用户ID号,执行如下命令

cat /etc/passwd

在返回的一堆内容中 在某一行的内容中就会看到你的用户名,在这一航的第3 和 第4 列 就是你的用户ID 和 用户组 ID 我的是 1001

test:x:1001:1001::/home/test:/bin/bash

这样,在启动容器后,挂载宿主 主机 目录到 容器的脚本执行目录后,宿主主机下脚本的 写入权限就没问题了。

        如果你是使用 docker-compose 来部署开发环境的,那么就需要在配置 文件中 php-fpm 项目加入 user 参数,详情请看下方代码 第 12 行

version: "3"

service:
        zend-engine:
        image: "php:7-fpm"
        ports:
            - "9000:9000"
        container_name: "zend-engine"
        volumes: 
            - ./etc/php/php.ini:/usr/local/etc/php/php.ini
            - ./www/default:/var/www/html
        user: 1001:1001

自此,问题解决了!

参考文献:

Quickstart: Compose and Django | Docker Documentation

       Running Docker Containers as Current Host User - Juan Treminio - Senior Web Developer Blog

你可能感兴趣的:(运维,docker)