自定义 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 的官方版本镜像。新镜像发布有两个通道:stablelabs

稳定通道

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.21.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 功能、master 构建和 nightly 功能发布文档,请参阅 GitHub 上的 BuildKit 源代码仓库 中的描述。要获取所有可用镜像的完整列表,请访问 Docker Hub 上的 docker/dockerfile 仓库,以及 Docker Hub 上的 docker/dockerfile-upstream 仓库 以获取开发版本构建。

页面选项