amazon-web-services - 使用 for_each 在 Terraform 中创建多个别名记录
问题描述
我正在尝试使用 for_each 在 terraform 中创建多个别名 DNS 记录。指定别名的名称和区域 ID 时出现错误。我的问题是如何从定义为一组字符串的变量中读取?下面是我定义的代码块和变量:
resource "aws_route53_record" "alias_records" {
for_each = var.alias_names
zone_id = aws_route53_zone.zone.zone_id
name = each.key
type = "A"
alias {
name = var.alias_dns_names[each.key]
zone_id = var.alias_zone_ids[each.key]
evaluate_target_health = false
}
}
variable "alias_names" {
type = set(string)
}
variable "alias_dns_names" {
type = set(string)
}
variable "alias_zone_ids" {
type = set(string)
}
Error: Invalid index
on alias.tf line 8, in resource "aws_route53_record" "alias_records":
8: name = var.alias_dns_names[each.key]
This value does not have any indices.
Error: Invalid index
on alias.tf line 9, in resource "aws_route53_record" "alias_records":
9: zone_id = var.alias_zone_ids[each.key]
This value does not have any indices.
alias_names = [
"alias1",
"alias2",
"alias3"
}
alias_dns_names = [
"alias_dns_1",
"alias_dns_2",
"alias_dns_3"
}
alias_zone_ids = [
"alias_zone_1",
"alias_zone_2",
"alias_zone_3"
}
解决方案
集合数据结构是无序的,并且它的元素除了它们的值之外没有任何标识符,因此集合类型不适合您的用例。
由于您似乎在这里描述了同一底层对象的三个不同方面,我认为从您的模块中公开它的最方便的方法是作为对象映射,如下所示:
variable "aliases" {
type = map(object({
zone_id = string
dns_name = string
}))
}
然后,您可以单独使用此变量来捕获每个别名记录所需的所有三个值:
aliases = {
alias1 = {
zone_id = "alias_zone_1"
dns_name = "alias_dns_1"
}
alias2 = {
zone_id = "alias_zone_2"
dns_name = "alias_dns_2"
}
alias3 = {
zone_id = "alias_zone_3"
dns_name = "alias_dns_3"
}
}
任何数据类型的映射都可以直接与资源for_each
一起使用,each.key
表示映射键并each.value
表示值。因此,您可以像这样更改资源块:
resource "aws_route53_record" "alias_records" {
for_each = var.aliases
zone_id = aws_route53_zone.zone.zone_id
name = each.key
type = "A"
alias {
zone_id = each.value.zone_id
name = each.value.dns_name
evaluate_target_health = false
}
}
因为地图的元素是对象,所以您可以访问它们each.value
以获取与原始地图中的每个键对应的zone_id
和dns_name
值。
推荐阅读
- apache-spark - 未找到 AWS EMR psycopg2 模块
- node.js - 如何在客户端显示 GraphQL 模式(邮递员等测试工具)
- docker - localstack docker 给出错误 Permission denied: '/tmp/localstack/server.test.pem.key'
- java - 如何使用 jpa 运行存储过程 CREATE 查询
- ios - 如何使用集合视图/ segue 传递数据?
- python - 无法将自定义数据集加载到经过预训练以进行特征提取的 cnn
- python - 尝试运行 Stanford CoreNLP 时出现预期 EOF 错误
- python - 使用 TkInter 设置不可交互(点击)覆盖
- reactjs - 如何使用 Unicode 和 React 显示 Fontawesome 图标?
- jupyter-notebook - jupyter notebook 只接受大写字母作为输入 IN [ ],不接受 [ ]