矩阵目标

矩阵策略允许您根据指定的参数将单个目标分解为多个不同的变体。这与GitHub Actions 的矩阵策略类似。您可以使用它来减少 Bake 定义中的重复。

matrix 属性是参数名称到值列表的映射。Bake 将每个可能的组合值都作为单独的目标构建。

每个生成的 target 必须具有唯一名称。要指定 target 名称的解析方式,请使用 name 属性。

以下示例将 app target 解析为 app-fooapp-bar。它还使用矩阵值来定义target 构建阶段

target "app" {
  name = "app-${tgt}"
  matrix = {
    tgt = ["foo", "bar"]
  }
  target = tgt
}
$ docker buildx bake --print app
[+] Building 0.0s (0/0)
{
  "group": {
    "app": {
      "targets": [
        "app-foo",
        "app-bar"
      ]
    },
    "default": {
      "targets": [
        "app"
      ]
    }
  },
  "target": {
    "app-bar": {
      "context": ".",
      "dockerfile": "Dockerfile",
      "target": "bar"
    },
    "app-foo": {
      "context": ".",
      "dockerfile": "Dockerfile",
      "target": "foo"
    }
  }
}

多个轴

您可以在矩阵中指定多个键以在多个轴上派生目标。使用多个矩阵键时,Bake 会构建所有可能的变体。

以下示例构建四个目标

  • app-foo-1-0
  • app-foo-2-0
  • app-bar-1-0
  • app-bar-2-0
target "app" {
  name = "app-${tgt}-${replace(version, ".", "-")}"
  matrix = {
    tgt = ["foo", "bar"]
    version = ["1.0", "2.0"]
  }
  target = tgt
  args = {
    VERSION = version
  }
}

每个矩阵目标的多个值

如果您想区分不仅仅是单个值的矩阵,可以使用映射作为矩阵值。Bake 为每个映射创建一个目标,您可以使用点表示法访问嵌套值。

以下示例构建两个目标

  • app-foo-1-0
  • app-bar-2-0
target "app" {
  name = "app-${item.tgt}-${replace(item.version, ".", "-")}"
  matrix = {
    item = [
      {
        tgt = "foo"
        version = "1.0"
      },
      {
        tgt = "bar"
        version = "2.0"
      }
    ]
  }
  target = item.tgt
  args = {
    VERSION = item.version
  }
}