Docker:创建的文件在图层之间消失

时间:2017-11-30 13:34:41

标签: docker dockerfile mkdir

运行Docker版本17.06.0-ce,构建02c1d87,我有一个如下所示的dockerfile:

FROM maven:3.5.2-jdk-8-alpine as builder

RUN chmod -R 777 /root/.m2 &&\
 mkdir -p /root/.m2/repository/com/foo/bar &&\
 echo "Text" > /root/.m2/repository/com/foo/bar/baz.txt &&\
 ls -R -a -l /root/.m2/repository/com/foo
RUN ls -R -a -l /root/.m2/repository/com/foo

第一个RUN命令成功创建了一个文件,但第二个命令找不到它:

Step 1/46 : FROM maven:3.5.2-jdk-8-alpine as builder
 ---> 293423a981a7
Step 2/46 : RUN chmod -R 777 /root/.m2 && mkdir -p /root/.m2/repository/com/foo/bar && echo "Text" > /root/.m2/repository/com/foo/bar/baz.txt && ls -R -a -l /root/.m2/repository/com/foo
 ---> Running in a1c0fd142856
/root/.m2/repository/com/foo:
total 12
drwxr-xr-x    3 root     root          4096 Nov 30 13:32 .
drwxr-xr-x    3 root     root          4096 Nov 30 13:32 ..
drwxr-xr-x    2 root     root          4096 Nov 30 13:32 bar

/root/.m2/repository/com/foo/bar:
total 12
drwxr-xr-x    2 root     root          4096 Nov 30 13:32 .
drwxr-xr-x    3 root     root          4096 Nov 30 13:32 ..
-rw-r--r--    1 root     root             5 Nov 30 13:32 baz.txt
 ---> b997ccbfd5b0
Step 3/46 : RUN ls -R -a -l /root/.m2/repository/com/foo
 ---> Running in 603671c87ecc
ls: /root/.m2/repository/com/foo: No such file or directory
The command '/bin/sh -c ls -R -a -l /root/.m2/repository/com/foo' returned a non-zero code: 1

发生了什么事? (注意:这是一个玩具示例,但是存在一个真正的问题,即安装到Maven存储库中的JAR似乎在层之间消失。)

1 个答案:

答案 0 :(得分:3)

upstream maven image将此目录定义为卷。一旦图像执行此操作,您就无法可靠地更改图像中的该目录。

来自他们的Dockerfile:

ARG USER_HOME_DIR="/root"
...
VOLUME "$USER_HOME_DIR/.m2"

Dockerfile documentation描述了这种行为:

  

更改Dockerfile中的卷:如果任何构建步骤在声明后更改了卷中的数据,那么这些更改将被丢弃。

您的选择是:

  • 使用另一个目录进行构建
  • 请求上游图像删除此VOLUME定义
  • 在没有这个定义的情况下构建您自己的图像(它很容易分叉他们的回购并自己构建)

有关详细信息,我可以看到有关此行为及其产生的问题的旧blog post