正常情况下,容器内部创建的文件目录写入权限是没问题的,并且是以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"