【发布时间】:2017-11-24 18:31:55
【问题描述】:
类似于SO post about replicating UID/GID in container from host,但是如何使用具有复制 UID 和 GID 的用户构建映像?最好,你如何使用 dockerfile 来做这件事?
我可以使用 bash 脚本来完成:
#!/bin/bash
# current uid and gid
curr_uid=`id -u`
curr_gid=`id -g`
# create bb.dockerfile:
cat << EOF1 > bb.dockerfile
FROM ubuntu:xenial-20170214
ARG UNAME=testuser
EOF1
echo ARG UID=${curr_uid} >> bb.dockerfile
echo ARG GID=${curr_gid} >> bb.dockerfile
cat << EOF2 >> bb.dockerfile
RUN groupadd -g \$GID \$UNAME
RUN useradd -m -u \$UID -g \$GID -s /bin/bash \$UNAME
USER \$UNAME
CMD /bin/bash
EOF2
docker build -f bb.dockerfile -t testimg .
这个 bash 将生成一个如下所示的 docker 文件并在其上构建。
FROM ubuntu:xenial-20170214
ARG UNAME=testuser
ARG UID=1982
ARG GID=1982
RUN groupadd -g $GID $UNAME
RUN useradd -m -u $UID -g $GID -s /bin/bash $UNAME
USER $UNAME
CMD /bin/bash
我要的是从 dockerfile 中删除硬编码的主机 UID 1982 和 GID 1982。
【问题讨论】:
标签: docker permissions dockerfile