如何在docker容器文件夹中提供文件夹权限

时间:2017-08-31 03:11:15

标签: docker permissions dockerfile permission-denied

我在Dockerfile中创建了一个文件夹,我想给它一个写权限。但是当我尝试这样做时,我得到了许可被拒绝的错误

FROM python:2.7
RUN pip install Flask==0.11.1 
RUN useradd -ms /bin/bash admin
USER admin
COPY app /app
WORKDIR /app
RUN chmod 777 /app
CMD ["python", "app.py"] 

我的错误是

PS C:\Users\Shivanand\Documents\Notes\Praneeth's work\Flask> docker build -t 
shivanand3939/test .
Sending build context to Docker daemon  209.9kB
Step 1/8 : FROM python:2.7
---> 8a90a66b719a
Step 2/8 : RUN pip install Flask==0.11.1
---> Using cache
---> 6dc114bd7cf1
Step 3/8 : RUN useradd -ms /bin/bash admin
---> Using cache
---> 1cfdb6eea7dc
Step 4/8 : USER admin
---> Using cache
---> 27c5e8b09f15
Step 5/8 : COPY app /app
---> Using cache
---> 5d628573b24f
Step 6/8 : WORKDIR /app
---> Using cache
---> 351e19a5a007
Step 7/8 : RUN chmod 777 /app
---> Running in aaad3c79e0f4
**chmod: changing permissions of ‘/app’: Operation not permitted
The command '/bin/sh -c chmod 777 /app' returned a non-zero code: 1**

如何为Docker容器中的app文件夹提供写入权限

2 个答案:

答案 0 :(得分:19)

我猜你正在切换到用户“admin”,它没有更改/ app目录权限的所有权。使用“root”用户更改所有权。 Dockerfile下面为我工作 -

FROM python:2.7
RUN pip install Flask==0.11.1 
RUN useradd -ms /bin/bash admin
COPY app /app
WORKDIR /app
RUN chown -R admin:admin /app
RUN chmod 755 /app
USER admin
CMD ["python", "app.py"] 

PS - 尽量摆脱“777”的许可。我暂时试图在Dockerfile上面做这件事。

答案 1 :(得分:0)

正如其他用户已经指出的那样,将USER admin移至下一个步骤

FROM python:2.7
RUN pip install Flask==0.11.1 
RUN useradd -ms /bin/bash admin
COPY --chown=admin:admin app /app
WORKDIR /app
USER admin
CMD ["python", "app.py"] 

对于版本release v17.09.0-ce和更高版本,您可以在--chown=<user>:<group>ADD命令中使用可选标志COPY

例如

COPY --chown=<user>:<group> <hostPath> <containerPath>

-chown标志的文档记录在Dockerfile Reference page上。