矩阵目标

矩阵策略允许你根据指定的参数将单一目标分叉成多个不同的变体。其工作方式类似于 GitHub Actions 的矩阵策略。 你可以在 Bake 定义中使用此功能以减少重复。

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

每个生成的目标必须具有唯一的名称。要指定目标名称应如何解析,请使用 name 属性。

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

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
  }
}