在将非root用户添加到sudoers组的镜像构建过程中,无法创建文件夹。这是我的Dockerfile:
FROM ubuntu:16.04
RUN apt-get update && \
apt-get -y install sudo
RUN adduser --disabled-password --gecos '' newuser \
&& adduser newuser sudo \
&& echo '%sudo ALL=(ALL:ALL) ALL' >> /etc/sudoers
USER newuser
RUN mkdir -p /newfolder
WORKDIR /newfolder
我收到错误消息:
mkdir: cannot create directory '/newfolder': Permission denied
最佳答案
Docker容器内的文件系统就像Docker容器外的文件系统一样工作:如果要创建文件或目录,则需要适当的权限。在这种情况下,您尝试以非root用户身份创建/newfolder
(因为USER
指令更改了用于运行其后所有命令的UID)。那是行不通的,因为/
属于root
并具有dr-xr-xr-x
模式。
请尝试:
RUN mkdir -p /newfolder
RUN chown newuser /newfolder
USER newuser
WORKDIR /newfolder
这会将目录创建为
root
,然后对其进行chown
。关于ubuntu - 无法创建目录。权限在Docker容器内被拒绝,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/45553074/