导出器概述

导出器将您的构建结果保存为指定的输出类型。您可以使用 --output CLI 选项来指定要使用的导出器。Buildx 支持以下导出器:

  • image: 将构建结果导出到容器镜像。
  • registry: 将构建结果导出到容器镜像,并将其推送到指定的 Registry。
  • local: 将构建的根文件系统导出到本地目录。
  • tar: 将构建的根文件系统打包成本地 tarball。
  • oci: 将构建结果导出到本地文件系统中,采用 OCI 镜像布局 格式。
  • docker: 将构建结果导出到本地文件系统中,采用 Docker 镜像规范 v1.2.0 格式。
  • cacheonly: 不导出构建输出,但运行构建并创建缓存。

使用导出器

要指定导出器,请使用以下命令语法:

$ docker buildx build --tag <registry>/<image> \
  --output type=<TYPE> .

大多数常见用例不需要您显式指定要使用哪个导出器。您只需在打算自定义输出或要将其保存到磁盘时指定导出器。--load--push 选项允许 Buildx 推断要使用的导出器设置。

例如,如果您将 --push 选项与 --tag 结合使用,Buildx 会自动使用 image 导出器,并配置导出器将结果推送到指定的 Registry。

为了充分利用 BuildKit 提供的各种导出器的灵活性,您可以使用 --output 标志来配置导出器选项。

用例

每种导出器类型都设计用于不同的用例。以下章节介绍了一些常见场景,以及如何使用导出器生成您需要的输出。

加载到镜像存储

Buildx 通常用于构建可以加载到镜像存储的容器镜像。这就是 docker 导出器的用武之地。以下示例演示了如何使用 docker 导出器构建镜像,并使用 --output 选项将该镜像加载到本地镜像存储:

$ docker buildx build \
  --output type=docker,name=<registry>/<image> .

如果您提供 --tag--load 选项,Buildx CLI 将自动使用 docker 导出器并将其加载到镜像存储。

$ docker buildx build --tag <registry>/<image> --load .

使用 docker 驱动程序构建的镜像会自动加载到本地镜像存储。

加载到镜像存储的镜像在构建完成后立即可用于 docker run,当您运行 docker images 命令时,将在镜像列表中看到它们。

推送到 Registry

要将构建的镜像推送到容器 Registry,您可以使用 registryimage 导出器。

当您将 --push 选项传递给 Buildx CLI 时,您就指示 BuildKit 将构建的镜像推送到指定的 Registry:

$ docker buildx build --tag <registry>/<image> --push .

在底层,这使用了 image 导出器,并设置了 push 参数。这与使用 --output 选项的长格式命令相同:

$ docker buildx build \
  --output type=image,name=<registry>/<image>,push=true .

您也可以使用 registry 导出器,它执行相同的操作:

$ docker buildx build \
  --output type=registry,name=<registry>/<image> .

导出镜像布局到文件

您可以使用 ocidocker 导出器将构建结果保存为本地文件系统上的镜像布局。这两种导出器都会生成一个包含相应镜像布局的 tar 存档文件。dest 参数定义了 tarball 的目标输出路径。

$ docker buildx build --output type=oci,dest=./image.tar .
[+] Building 0.8s (7/7) FINISHED
 ...
 => exporting to oci image format                                                                     0.0s
 => exporting layers                                                                                  0.0s
 => exporting manifest sha256:c1ef01a0a0ef94a7064d5cbce408075730410060e253ff8525d1e5f7e27bc900        0.0s
 => exporting config sha256:eadab326c1866dd247efb52cb715ba742bd0f05b6a205439f107cf91b3abc853          0.0s
 => sending tarball                                                                                   0.0s
$ mkdir -p out && tar -C out -xf ./image.tar
$ tree out
out
├── blobs
│   └── sha256
│       ├── 9b18e9b68314027565b90ff6189d65942c0f7986da80df008b8431276885218e
│       ├── c78795f3c329dbbbfb14d0d32288dea25c3cd12f31bd0213be694332a70c7f13
│       ├── d1cf38078fa218d15715e2afcf71588ee482352d697532cf316626164699a0e2
│       ├── e84fa1df52d2abdfac52165755d5d1c7621d74eda8e12881f6b0d38a36e01775
│       └── fe9e23793a27fe30374308988283d40047628c73f91f577432a0d05ab0160de7
├── index.json
├── manifest.json
└── oci-layout

导出文件系统

如果您不想从构建结果构建镜像,而是想导出构建的文件系统,则可以使用 localtar 导出器。

local 导出器将文件系统解压到指定位置的目录结构中。tar 导出器创建一个 tarball 存档文件。

$ docker buildx build --output type=local,dest=<path/to/output> .

local 导出器在多阶段构建中很有用,因为它允许您仅导出最少量的构建 artifact,例如自包含二进制文件。

仅缓存导出

如果您只想运行构建而不导出任何输出,则可以使用 cacheonly 导出器。例如,如果您想运行测试构建,或者如果您想先运行构建,然后使用后续命令创建导出,这会很有用。cacheonly 导出器会创建构建缓存,因此任何后续构建都会立即完成。

$ docker buildx build --output type=cacheonly

如果您未指定导出器,并且未提供诸如 --load 之类的自动选择相应导出器的简写选项,则 Buildx 默认使用 cacheonly 导出器。除非您使用 docker 驱动程序构建,在这种情况下您使用 docker 导出器。

当使用 cacheonly 作为默认值时,Buildx 会记录警告消息:

$ docker buildx build .
WARNING: No output specified with docker-container driver.
         Build result will only remain in the build cache.
         To push result image into registry use --push or
         to load image into docker use --load

多个导出器

要求: Docker Buildx [0.13.0]((/manuals/build/release-notes.md#0130) 及更高版本

您可以通过多次指定 --output 标志,为任何给定构建使用多个导出器。这要求 Buildx 和 BuildKit 版本均为 0.13.0 或更高版本。

以下示例运行一次构建,使用了三种不同的导出器:

  • registry 导出器,用于将镜像推送到 Registry
  • local 导出器,用于将构建结果提取到本地文件系统
  • --load 标志(image 导出器的简写),用于将结果加载到本地镜像存储。
$ docker buildx build \
  --output type=registry,tag=<registry>/<image> \
  --output type=local,dest=<path/to/output> \
  --load .

配置选项

本节介绍了一些适用于导出器的配置选项。

此处描述的选项至少在两种或更多导出器类型中通用。此外,不同的导出器类型也支持特定参数。有关适用配置参数的更多信息,请参阅每个导出器的详细页面。

此处描述的通用参数包括:

压缩

导出压缩输出时,您可以配置要使用的具体压缩算法和级别。虽然默认值提供了良好的开箱即用体验,但您可能希望调整参数以优化存储成本与计算成本。更改压缩参数可以减少所需的存储空间并提高镜像下载时间,但会增加构建时间。

要选择压缩算法,您可以使用 compression 选项。例如,要构建使用 compression=zstdimage

$ docker buildx build \
  --output type=image,name=<registry>/<image>,push=true,compression=zstd .

alongside compression 参数一起使用 compression-level=<value> 选项,为支持的算法选择压缩级别:

  • gzipestargz 为 0-9
  • zstd 为 0-22

一般来说,数值越高,生成的文件越小,压缩运行所需的时间也越长。

如果请求的压缩算法与之前的压缩算法不同,使用 force-compression=true 选项可以强制重新压缩从之前镜像导入的层。

注意

gzipestargz 压缩方法使用 compress/gzip,而 zstd 使用 github.com/klauspost/compress/zstd

OCI 媒体类型

imageregistryocidocker 导出器创建容器镜像。这些导出器支持 Docker 媒体类型(默认)和 OCI 媒体类型:

要导出设置了 OCI 媒体类型的镜像,请使用 oci-mediatypes 属性。

$ docker buildx build \
  --output type=image,name=<registry>/<image>,push=true,oci-mediatypes=true .

下一步

阅读有关每个导出器的内容,了解它们的工作原理和使用方法:

页面选项