在构建Docker映像时,如何将文件复制到映像中,以使生成的文件由根用户以外的用户拥有?
当前回答
对于v17.09.0-ce及更新版本
使用可选标志——chown=<user>:<group>,使用ADD或COPY命令。
例如
COPY --chown=<user>:<group> <hostPath> <containerPath>
——chown标志的文档现在在主Dockerfile Reference页面上。
版本34263已经合并,在v17.09.0-ce中可用。
对于v17.09.0-ce之前的版本
Docker不支持除了root用户的COPY。执行COPY命令后需要chown / chmod文件。
示例Dockerfile:
from centos:6
RUN groupadd -r myuser && adduser -r -g myuser myuser
USER myuser
#Install code, configure application, etc...
USER root
COPY run-my-app.sh /usr/local/bin/run-my-app.sh
RUN chown myuser:myuser /usr/local/bin/run-my-app.sh && \
chmod 744 /usr/local/bin/run-my-app.sh
USER myuser
ENTRYPOINT ["/usr/local/bin/run-my-app.sh"]
在v17.09.0-ce之前,COPY命令的Dockerfile Reference说:
所有新创建的文件和目录的UID和GID都是0。
历史 此功能已通过多个GitHub问题跟踪:6119,9943,13600,27303,28499,Issue 30110。
第34263版实现了可选标志功能,第467版更新了文档。
其他回答
对于v17.09.0-ce及更新版本
使用可选标志——chown=<user>:<group>,使用ADD或COPY命令。
例如
COPY --chown=<user>:<group> <hostPath> <containerPath>
——chown标志的文档现在在主Dockerfile Reference页面上。
版本34263已经合并,在v17.09.0-ce中可用。
对于v17.09.0-ce之前的版本
Docker不支持除了root用户的COPY。执行COPY命令后需要chown / chmod文件。
示例Dockerfile:
from centos:6
RUN groupadd -r myuser && adduser -r -g myuser myuser
USER myuser
#Install code, configure application, etc...
USER root
COPY run-my-app.sh /usr/local/bin/run-my-app.sh
RUN chown myuser:myuser /usr/local/bin/run-my-app.sh && \
chmod 744 /usr/local/bin/run-my-app.sh
USER myuser
ENTRYPOINT ["/usr/local/bin/run-my-app.sh"]
在v17.09.0-ce之前,COPY命令的Dockerfile Reference说:
所有新创建的文件和目录的UID和GID都是0。
历史 此功能已通过多个GitHub问题跟踪:6119,9943,13600,27303,28499,Issue 30110。
第34263版实现了可选标志功能,第467版更新了文档。
推荐文章
- PYTHONUNBUFFERED在docker文件中的用途是什么?
- 如何在Dockerfile CMD中使用变量?
- 将主机端口转发到docker容器
- “docker compose”与“docker-compose”的区别
- /bin/sh: apt-get:未找到
- 如何在docker映像的新容器中运行bash ?
- docker -撰写持久数据MySQL
- 从主机连接到docker容器中的mysql
- 当我使用Alpine作为基本图像时,如何添加用户?
- Docker -绑定0.0.0.0:4000失败:端口已经分配
- 将Python诗歌与Docker集成
- 如何在系统启动时运行docker-compose up -d ?
- 如何确定一个进程是否运行在lxc/Docker内部?
- 在docker容器上挂载多个卷?
- Kubernetes如何使部署更新映像