自定义 Dockerfile 语法
Dockerfile 前端
BuildKit 支持从容器镜像动态加载前端。要使用外部 Dockerfile 前端,你的 Dockerfile 的第一行需要设置 syntax 指令,指向你要使用的特定镜像。
# syntax=[remote image reference]例如:
# syntax=docker/dockerfile:1
# syntax=docker.io/docker/dockerfile:1
# syntax=example.com/user/repo:tag@sha256:abcdef...你还可以使用预定义的 BUILDKIT_SYNTAX 构建参数在命令行上设置前端镜像引用。
$ docker build --build-arg BUILDKIT_SYNTAX=docker/dockerfile:1 .
这定义了用于构建 Dockerfile 的 Dockerfile 语法的位置。BuildKit 后端允许无缝使用以 Docker 镜像形式分发并在容器沙盒环境中执行的外部实现。
自定义 Dockerfile 实现允许你:
- 无需更新 Docker 守护程序即可自动获取错误修复。
- 确保所有用户都使用相同的实现来构建你的 Dockerfile。
- 无需更新 Docker 守护程序即可使用最新功能。
- 在 Docker 守护程序集成新功能或第三方功能之前进行尝试。
- 使用替代构建定义,或创建你自己的。
- 构建你自己的具有自定义功能的 Dockerfile 前端。
注意BuildKit 附带一个内置的 Dockerfile 前端,但建议使用外部镜像,以确保所有用户在构建器上使用相同版本,并自动获取错误修复,而无需等待新版本的 BuildKit 或 Docker Engine。
官方版本
Docker 在 Docker Hub 上的 docker/dockerfile 仓库下分发可用于构建 Dockerfile 的官方镜像。新镜像发布有两个通道:stable 和 labs。
稳定通道
stable 通道遵循语义版本控制。例如:
docker/dockerfile:1- 保持与最新的1.x.x小版本和补丁版本同步更新。docker/dockerfile:1.2- 保持与最新的1.2.x补丁版本同步更新,一旦发布1.3.0版本,将停止接收更新。docker/dockerfile:1.2.1- 不可变:永不更新。
我们建议使用 docker/dockerfile:1,它始终指向版本 1 语法的最新稳定版本,并接收版本 1 发布周期的“次要”和“补丁”更新。BuildKit 在执行构建时会自动检查语法的更新,确保你使用的是最新版本。
如果使用了特定版本,例如 1.2 或 1.2.1,则需要手动更新 Dockerfile 才能继续接收错误修复和新功能。旧版本的 Dockerfile 仍然与新版本的构建器兼容。
实验室通道
labs 通道提供对 stable 通道中尚未提供的 Dockerfile 功能的早期访问。labs 镜像与稳定版本同时发布,并遵循相同的版本模式,但使用 -labs 后缀,例如:
docker/dockerfile:labs-labs通道的最新版本。docker/dockerfile:1-labs- 与dockerfile:1相同,但启用了实验功能。docker/dockerfile:1.2-labs- 与dockerfile:1.2相同,但启用了实验功能。docker/dockerfile:1.2.1-labs- 不可变:永不更新。与dockerfile:1.2.1相同,但启用了实验功能。
选择最适合你需求的通道。如果你想受益于新功能,请使用 labs 通道。labs 通道中的镜像包含 stable 通道中的所有功能,以及早期访问功能。labs 通道中的稳定功能遵循语义版本控制,但早期访问功能不遵循,并且新版本可能不向后兼容。请锁定版本以避免处理破坏性更改。
其他资源
有关 labs 功能、主构建和夜间功能发布的文档,请参阅 GitHub 上的 BuildKit 源代码仓库中的描述。有关可用镜像的完整列表,请访问 Docker Hub 上的 docker/dockerfile 仓库,以及 Docker Hub 上的 docker/dockerfile-upstream 仓库以获取开发构建。