使用 terraform 0.12+ 计算输出变量

Count in output vars with terraform 0.12+

我有条件地创建一个资源,计数为:

resource "aws_kms_key" "this" {
  count       = var.create_kms_key == true ? 1 : 0
  ...
}

然后如何有条件地输出此资源的值?我试着玩了一下,Terraform 似乎自相矛盾

首先它告诉我在输出中使用计数。

For example, to correlate with indices of a referring resource, use:
    aws_kms_key.this[count.index]

然后当我尝试时它说我不能使用计数。

The "count" object can be used only in "resource" and "data" blocks, and only
when the "count" argument is set.

以前我们可以执行如下操作,但现在会触发我之前发布的计数错误。

output "kms_key_arn" {
    value = aws_kms_key.this.*.arn
}

现在知道这是怎么回事了吗?

谢谢,

当为资源设置 count 时,对该资源的引用然后是 return 对象列表而不是单个对象,因此我们需要在编写其他表达式时牢记这一点.

在您的情况下,该列表可以有零个或一个元素,因此我们必须在引用它的任何表达式中处理这两种情况。

要编写从该资源传播属性的输出,我们需要决定在列表为空的情况下我们将 return 做什么。例如,在这种情况下,我们可以选择将输出设置为 null

output "kms_key_arn" {
    value = concat(aws_kms_key.this.*.arn, [null])[0]
}

这里的技巧是将具有零个或一个元素的列表更改为具有一个或两个元素的列表,然后取第一个元素。 concat 函数可能有两种可能性 return:

["arn:aws:....", null]
[null]

在这两种情况下,使用[0]取第零个元素都是有效的。在第二种情况下,它将 select null 作为结果。


如果您有其他资源也以 var.create_kms_key 为条件,则此方法有一个变体:

resource "aws_kms_key" "example" {
  count = var.create_kms_key ? 1 : 0

  # ...
}

resource "anything_else" "example" {
  count = length(aws_kms_key.example) # only if KMS key is created

  any_argument = aws_kms_key.example[count.index].arn
}

此变体依赖于这两个资源对 count 具有相同值的事实,因此我们可以在第二个资源中使用 count.index 以便与第一个资源的实例相关联。 count.index 只能在设置了 count 的资源中使用,但在这种特定情况下它 设置的,因为我们将 count 设置为我们知道所有 count.index 值都在该资源的对象列表范围内的其他资源的长度。