【发布时间】:2020-11-02 05:18:39
【问题描述】:
假设我正在使用 Docker Buildkit 构建映像。我的图像来自多级 Dockerfile,如下所示:
FROM node:12 AS some-expensive-base-image
...
FROM some-expensive-base-image AS my-app
...
我现在正在尝试构建这两个图像。假设我将这些推送到 Docker Hub。如果我要使用 Docker Buildkit 的外部缓存功能,那么我想通过在构建 some-expensive-base-image 目标时拉入远程 some-expensive-base-image:latest 图像作为缓存来尝试节省我的 CI 管道上的构建时间。而且,我想同时拉入刚刚构建的some-expensive-base-image 图像和远程my-app:latest 图像作为后一个图像的缓存。我相信我需要两者,以防止需要重建 some-expensive-base-image 的步骤,因为......嗯......它们很昂贵。
这是我的构建脚本的样子:
export DOCKER_BUILDKIT=1
docker build --build-arg BUILDKIT_INLINE_CACHE=1 --cache-from some-expensive-base-image:latest --target some-expensive-base-image -t some-expensive-base-image:edge .
docker build --build-arg BUILDKIT_INLINE_CACHE=1 --cache-from some-expensive-base-image:edge --cache-from my-app:latest --target my-app -t my-app:edge .
我的问题:--cache-from 参数的顺序对第二个docker build 是否重要?
我在此构建的 CI 管道上得到了不一致的结果。在构建后一个映像时会发生缓存未命中,即使没有任何会导致缓存破坏的代码更改。可以毫无问题地拉出 Cache Minefest。有时会拉取缓存映像,但有时需要重新运行后一个目标的所有步骤。我不知道为什么。
是否应该在我的脚本中运行 docker build 命令之前尝试 docker pull 两个图像?
另外,我知道我在示例中提到了 Docker Hub,但在现实生活中,我的应用程序使用 AWS ECR 作为其远程 Docker 存储库。这对于正确的 Buildkit 功能是否重要?
【问题讨论】:
标签: docker caching docker-buildkit