Bake 中的表示式求值

HCL 格式的 Bake 檔案支援表示式求值,這使您能夠執行算術運算、有條件地設定值等等。

算術運算

您可以在表示式中執行算術運算。以下示例展示瞭如何將兩個數字相乘。

docker-bake.hcl
sum = 7*6

target "default" {
  args = {
    answer = sum
  }
}

使用 --print 標誌列印 Bake 檔案將顯示 answer 構建引數的求值結果。

$ docker buildx bake --print
{
  "target": {
    "default": {
      "context": ".",
      "dockerfile": "Dockerfile",
      "args": {
        "answer": "42"
      }
    }
  }
}

三元運算子

您可以使用三元運算子有條件地註冊值。

以下示例僅在變數不為空時新增標籤,使用了內建的 notequal 函式

docker-bake.hcl
variable "TAG" {}

target "default" {
  context="."
  dockerfile="Dockerfile"
  tags = [
    "my-image:latest",
    notequal("",TAG) ? "my-image:${TAG}": ""
  ]
}

在這種情況下,TAG 是一個空字串,因此生成的構建配置只包含硬編碼的 my-image:latest 標籤。

$ docker buildx bake --print
{
  "target": {
    "default": {
      "context": ".",
      "dockerfile": "Dockerfile",
      "tags": ["my-image:latest"]
    }
  }
}

帶變數的表示式

您可以將表示式與變數一起使用,以有條件地設定值或執行算術運算。

以下示例使用表示式根據變數的值設定值。如果變數 FOO 大於 5,則 v1 構建引數設定為“higher”,否則設定為“lower”。如果 IS_FOO 變數為 true,則 v2 構建引數設定為“yes”,否則設定為“no”。

docker-bake.hcl
variable "FOO" {
  default = 3
}

variable "IS_FOO" {
  default = true
}

target "app" {
  args = {
    v1 = FOO > 5 ? "higher" : "lower"
    v2 = IS_FOO ? "yes" : "no"
  }
}

使用 --print 標誌列印 Bake 檔案將顯示 v1v2 構建引數的求值結果。

$ docker buildx bake --print app
{
  "group": {
    "default": {
      "targets": ["app"]
    }
  },
  "target": {
    "app": {
      "context": ".",
      "dockerfile": "Dockerfile",
      "args": {
        "v1": "lower",
        "v2": "yes"
      }
    }
  }
}