1

更新-> 对于所有有这个特殊问题的人,我找到了解决方案,它在这个问题的末尾。

更新 2 -> 我在这里提出的最后一个解决方案是错误的,请参阅最后的更新。

我正在从数据块中检索 cidr_blocks 列表以用作 aws_ec2_transit_gateway_route 上的值,但到目前为止,我无法遍历该列表以获取单个值并将其设置在适当的位置。我的 data_block.tf 的重要部分如下所示:

data "aws_vpc" "account_vpc" {
 provider = aws.dev
 count = "${length(data.aws_vpcs.account_vpcs.ids)}"
 id    = element(tolist(data.aws_vpcs.account_vpcs.ids), 0)
}

data "aws_subnet_ids" "account_subnets" {
 provider = aws.dev
 vpc_id   = element(tolist(data.aws_vpcs.account_vpcs.ids), 0)
}

data "aws_subnet" "cidrblocks" {
  provider = aws.dev
  for_each = data.aws_subnet_ids.account_subnets.ids
  id    = each.value
}

我打算使用它的部分是这个,tgw_rt.tf:

resource "aws_ec2_transit_gateway_route" "shared-routes" {
 provider                      = aws.shared
 #count = length(data.aws_subnet.cidrblocks.cidr_block)
 #destination_cidr_block         = lookup(data.aws_subnet.cidrblocks.cidr_block[count.index], element(keys(data.aws_subnet.cidrblocks.cidr_block[count.index]),0), "127.0.0.1/32")
 #destination_cidr_block          = data.aws_subnet.cidrblocks.cidr_block[count.index]
 #destination_cidr_block          = [data.aws_subnet.cidrblocks.*.cidr_block]
 destination_cidr_block          = [for s in data.aws_subnet.cidrblocks : s.cidr_block]
 /* for_each                         = [for s in data.aws_subnet.cidrblocks: {
   destination_cidr_block         = s.cidr_block
  }] */
 #destination_cidr_block         = [for s in data.aws_subnet.cidrblocks : s.cidr_block]
 #destination_cidr_block         = data.aws_subnet.cidrblocks.cidr_block[count.index]
 transit_gateway_attachment_id  = aws_ec2_transit_gateway_vpc_attachment.fromshared.id
 transit_gateway_route_table_id = aws_ec2_transit_gateway_route_table.shared.id
}

评论中的部分是我迄今为止尝试过的,但没有任何效果。使用该未注释部分时当前发生的错误是

Error: Incorrect attribute value type

  on modules/tgw/tgw_rt.tf line 20, in resource "aws_ec2_transit_gateway_route" "shared-routes":
  20:  destination_cidr_block          = [for s in data.aws_subnet.cidrblocks : s.cidr_block]
    |----------------
    | data.aws_subnet.cidrblocks is object with 3 attributes

Inappropriate value for attribute "destination_cidr_block": string required.

如果在场的地球形态之神之一能够阐明这个问题,我将不胜感激。

解决方案 - 这是错误的,因为它抱怨它是一个具有 3 个属性(3 个 Cidr 块)的对象,所以要迭代我必须使用这个:

destination_cidr_block          = element([for s in data.aws_subnet.cidrblocks : s.cidr_block], 0)

正确的解决方案解决方案是在@kyle 建议中添加一小部分,我必须使用一个对象来表示数据并将其转换为地图,你摇滚@kyle:

for_each                         = {for s in data.aws_subnet.cidrblocks: s.cidr_block => s}
destination_cidr_block           = each.value.cidr_block

谢谢大家

4

1 回答 1

1

我没用过data.aws_subnet,但我认为你的尝试很接近for_each-

resource "aws_ec2_transit_gateway_route" "shared-routes" {
...
 for_each                = [for s in data.aws_subnet.cidrblocks: s.cidr_block]
 destination_cidr_block  = each.value
...
}
于 2020-06-06T17:40:43.200 回答