0

我想创建一个可以接受环境输入的模块(dev、test、prod)并使用适当的标签创建子网的数量(每个环境的“app”和“db”子网)。例如 Name=dev-app 该模块应该灵活地添加/删除子网,因为输入变量被更新。我的模板如下所示

variable "environments" {
  type = map(object({
    app_subnet_cidr    = string
    db_subnet_cidr = string
  }))

  default = {
dev = {
    app_subnet_cidr = "192.168.219.0/24"
    db_subnet_cidr = "192.168.218.0/24"
  }
test = {
    app_subnet_cidr = "192.168.118.0/24"
    db_subnet_cidr = "192.168.119.0/24"
  }
}
}


resource "aws_subnet" "this" {
  for_each = var.environments
  vpc_id     = var.vpc_id
  cidr_block = {Don't know what to use here}

  tags {
  Name = {Don't know what to use here}
}
}

我指的是下面的文章。 https://www.hashicorp.com/blog/terraform-0-12-rich-value-types/ 问题2:如何为以下模块定义“网络”变量

module "subnets" {
  source = "./subnets"

  parent_vpc_id = "vpc-abcd1234"
  networks = {
    production_a = {
      network_number    = 1
      availability_zone = "us-east-1a"
    }
    production_b = {
      network_number    = 2
      availability_zone = "us-east-1b"
    }
    staging_a = {
      network_number    = 1
      availability_zone = "us-east-1a"
    }
  }
}

https://www.hashicorp.com/blog/hashicorp-terraform-0-12-preview-for-and-for-each/

4

1 回答 1

0

您所指的博客文章是尚未完成的即将推出的功能的预览,因此它们不是最终发布功能的最佳参考。相反,请参阅资源的官方文档for_each

azurerm_resource_group该文档包括一个基于映射声明多个资源实例的示例。我们可以调整该示例以与您的一起使用var.environments,其中一个资源块描述“app”子网,一个单独的资源块描述“db”子网:

resource "aws_subnet" "app" {
  for_each = var.environments

  vpc_id     = var.vpc_id
  cidr_block = each.value.app_subnet_cidr

  tags = {
    Name = "${each.key}-app"
  }
}

resource "aws_subnet" "db" {
  for_each = var.environments

  vpc_id     = var.vpc_id
  cidr_block = each.value.db_subnet_cidr

  tags = {
    Name = "${each.key}-db"
  }
}

我不确定你的第二个问题与第一个问题的关系如何,但这里是如何声明一个变量networks,以便它接受一个类似于你在第二个示例中显示的值。

variable "networks" {
  type = map(object({
    network_number    = number
    availability_zone = string
  }))
}

如果您想了解有关第二个示例的更多信息,我建议您在 Stack Overflow 上开始一个新的单独问题。Stack Overflow 的惯例是为每个主题设置一个单独的问题,而不是一次提出多个问题。

于 2020-02-19T00:44:58.383 回答