【发布时间】:2021-02-28 04:34:38
【问题描述】:
我有一种情况,我正在尝试使用 Terraform 中的 cidrsubnet 函数动态创建一些子网。这是我的定义:
data "aws_availability_zones" "availability_zones" {
exclude_names = [
"us-west-2c",
"us-west-2d"
]
}
locals {
availability_zone_names = "${data.aws_availability_zones.availability_zones.names}"
}
resource "aws_subnet" "public_subnets" {
count = "${length(local.availability_zone_names)}"
vpc_id = "${aws_vpc.vpc.id}"
cidr_block = "${cidrsubnet(aws_vpc.vpc.cidr_block, 11, count.index)}"
availability_zone = "${local.availability_zone_names[count.index]}"
map_public_ip_on_launch = true
tags {
Name = "${var.name}-public.${local.availability_zone_names[count.index]}"
}
}
我只是尝试在该区域的两个可用区中创建这些子网(因此我排除了 2 个可用区。应用此代码后,我在尝试创建的子网之一中得到了我想要的结果. 但是,我试图获取 10.32.2.0/27 的地址的另一个子网的 cidr 块地址,但 cidrsubnet 函数正在生成 10.32.0.32/27。任何我出错的建议都会有所帮助。
计划产出
aws_subnet.public_subnets[1]
id: <computed>
arn: <computed>
assign_ipv6_address_on_creation: "false"
availability_zone: "us-west-2b"
availability_zone_id: <computed>
cidr_block: "10.32.0.32/27"
【问题讨论】:
-
什么是
aws_vpc.vpc.cidr_block? -
VPC cidr 为 10.32.0.0/16
标签: amazon-web-services terraform public subnet