矩阵目标
目录
矩阵策略允许您根据指定的参数将单个目标分解为多个不同的变体。这与GitHub Actions 的矩阵策略类似。您可以使用它来减少 Bake 定义中的重复。
matrix 属性是参数名称到值列表的映射。Bake 将每个可能的组合值都作为单独的目标构建。
每个生成的 target 必须具有唯一名称。要指定 target 名称的解析方式,请使用 name 属性。
以下示例将 app target 解析为 app-foo
和 app-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
}
}