Terraform如何根据工作空间在路由表中获取动态路由
UAT
resource "aws_vpn_gateway" "micorsoft_vpn_gw" {
vpc_id = aws_vpc.default.id
tags = {
Name = "micorsoft"
}
}
resource "aws_route_table" "private" {
vpc_id = aws_vpc.default.id
route {
cidr_block = "0.0.0.0/0"
nat_gateway_id = aws_nat_gateway.default.id
}
route {
cidr_block = "0.0.0.0/0"
gateway_id = aws_vpn_gateway.micorsoft_vpn_gw.id
}
tags = merge(map("Name", "${var.namespace}-${var.environment}"), var.tags)
}
DEV
resource "aws_route_table" "private" {
vpc_id = aws_vpc.default.id
route {
cidr_block = "0.0.0.0/0"
nat_gateway_id = aws_nat_gateway.default.id
}
tags = merge(map("Name", "${var.namespace}-${var.environment}"), var.tags)
}
如何实现这一点是基于工作空间/环境的动态方式
最佳答案
您可以使用dynamic block为此。
resource "aws_route_table" "private" {
vpc_id = aws_vpc.default.id
route {
cidr_block = "0.0.0.0/0"
nat_gateway_id = aws_nat_gateway.default.id
}
dynamic "route" {
for_each = var.env == "DEV" ? toset([]) : toset([1])
content {
cidr_block = "0.0.0.0/0"
gateway_id = aws_vpn_gateway.micorsoft_vpn_gw.id
}
}
tags = merge(map("Name", "${var.namespace}-${var.environment}"), var.tags)
}
基本上,当 var.env
为 DEV
时,不会创建第二个路由
。
关于amazon-web-services - Terraform如何在路由表中获取动态路由,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64334897/