首页 > 解决方案 > WSL 上的 Dockerfile VOLUME 命令行为不同

问题描述

按照本教程,我已设置 docker 以使用 WSL 2(运行 Ubuntu 20.04)。从 Dockerfile 构建图像时,我遇到了行为差异。我的示例 Dockerfile 包含以下步骤:

FROM busybox
VOLUME /foo
RUN touch /foo/bar.txt

docker build在我的 linux 机器(Fedora 33)上运行时,一切正常。从我的 WSL 机器运行时,我收到以下错误:

> [2/2] RUN touch /foo/bar.txt:
#5 0.221 touch: /foo/bar.txt: No such file or directory

似乎该VOLUME命令没有运行(失败的步骤是 2/2 而不是 3/3)。我找不到任何关于这种行为差异的文档。有人熟悉这种差异吗?有什么办法可以避免它们吗?

使用的 Docker 版本 -

在 Linux 本机 (Fedora 33) 上:

$ docker version
Client: Docker Engine - Community
 Version:           20.10.5
 API version:       1.41
 Go version:        go1.13.15
 Git commit:        55c4c88
 Built:             Tue Mar  2 20:19:16 2021
 OS/Arch:           linux/amd64
 Context:           default
 Experimental:      true

Server: Docker Engine - Community
 Engine:
  Version:          20.10.5
  API version:      1.41 (minimum version 1.12)
  Go version:       go1.13.15
  Git commit:       363e9a8
  Built:            Tue Mar  2 20:16:56 2021
  OS/Arch:          linux/amd64
  Experimental:     false
 containerd:
  Version:          1.4.4
  GitCommit:        05f951a3781f4f2c1911b05e61c160e9c30eaa8e
 runc:
  Version:          1.0.0-rc93
  GitCommit:        12644e614e25b05da6fd08a38ffa0cfe1903fdec
 docker-init:
  Version:          0.19.0
  GitCommit:        de40ad0

在 WSL 2(Ubuntu 20.04)上:

$ docker version
Client: Docker Engine - Community
 Cloud integration: 1.0.9
 Version:           20.10.5
 API version:       1.41
 Go version:        go1.13.15
 Git commit:        55c4c88
 Built:             Tue Mar  2 20:17:50 2021
 OS/Arch:           linux/amd64
 Context:           default
 Experimental:      true

Server: Docker Engine - Community
 Engine:
  Version:          20.10.5
  API version:      1.41 (minimum version 1.12)
  Go version:       go1.13.15
  Git commit:       363e9a8
  Built:            Tue Mar  2 20:15:47 2021
  OS/Arch:          linux/amd64
  Experimental:     false
 containerd:
  Version:          1.4.3
  GitCommit:        269548fa27e0089a8b8278fc4fc781d7f65a939b
 runc:
  Version:          1.0.0-rc92
  GitCommit:        ff819c7e9184c13b7c2607fe6c30ae19403a7aff
 docker-init:
  Version:          0.19.0
  GitCommit:        de40ad0

标签: dockerdockerfiledocker-volumewsl-2

解决方案


两台机器之间的区别在于 WSL 机器启用了 BuildKit 而 Linux 机器没有。 BuildKit 在 build 期间不应用该VOLUME命令,因此如果目录不存在,则不会创建该目录。

“正确”的解决方案是mkdir在使用它之前直接使用它来创建目录。如果这不可能,另一种解决方案是禁用 BuildKit(通过与这些说明相反的操作)。


推荐阅读