在将非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/

10-11 06:19