在构建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版更新了文档。
推荐文章
- 如何从docker更改默认docker注册表。IO到我的私人注册表?
- Docker- compose无法连接到Docker Daemon
- 单个命令停止和删除docker容器
- 使用GPU从docker容器?
- 如何使用本地映像作为dockerfile的基本映像?
- 谁能解释一下docker.sock
- 多重from是什么意思
- 通过映像名称停止Docker容器- Ubuntu
- 如果dockerfile的名称不是dockerfile,我如何构建一个dockerfile ?
- 守护进程的错误响应:已被集装箱使用"
- 如何从DockerFile运行docker实例?
- 我是否试图连接到启用TLS的没有TLS的守护进程?
- Docker -一种访问主机USB或串行设备的方法?
- Docker:无效引用格式
- 将AWS凭证传递给Docker容器的最佳方法是什么?