我有以下代码用于创建eni:
resource "aws_network_interface" "eth0" {
private_ips = "10.10.0.1"
security_groups = ["${aws_security_group.secg1.id}"]
subnet_id = "${element(data.aws_subnet_ids.sub01.ids,0)}"
lifecycle {
ignore_changes = ["subnet_id"]
}
}
以上代码在.12版中停止工作,而在.11版中工作。 我尝试了以下替换元素:
"tolist(data.aws_subnet_ids.trust-sub01.ids)[0]"
和:
"index(data.aws_subnet_ids.trust-sub01.ids)[0]"
两者都不起作用,这给我一个错误消息“子网ID不存在”
答案 0 :(得分:1)
您是否有理由不只是使用aws_subnet data source。您可以使用过滤器拨打返回子网的地址,然后使用其中的id
属性:
data "aws_subnet" "default" {
vpc_id = "vpc-0dfc13e14b4e1fa57"
filter {
name = "availability-zone-id"
values = ["use1-az4"]
}
}
resource "aws_network_interface" "eth0" {
private_ips = "172.31.16.1"
subnet_id = data.aws_subnet.default.id
lifecycle {
ignore_changes = ["subnet_id"]
}
}
如果您必须像使用aws_subnet_ids
那样为每个子网创建网络接口,则可以执行以下操作:
data "aws_subnet_ids" "default" {
vpc_id = "vpc-0dfc13e14b4e1fa57"
}
resource "aws_network_interface" "eth0" {
count = length(data.aws_subnet_ids.default.ids)
subnet_id = element(tolist(data.aws_subnet_ids.default.ids),count.index)
lifecycle {
ignore_changes = ["subnet_id"]
}
}