我有这个地形密码..。
// Route53 Zone
module "zones" {
source = "terraform-aws-modules/route53/aws//modules/zones"
version = "~> 1.2.0"
create = var.environment == "PRO" ? true : false
zones = {
"example.com" = {
comment = "example.com (production)"
tags = merge(var.global_tags, { environment = var.environment})
}
}
}
// Route53 Records
module "records" {
source = "terraform-aws-modules/route53/aws//modules/records"
version = "~> 1.2.0"
create = var.environment == "PRO" ? true : false
zone_name = keys(module.zones.this_route53_zone_zone_id)[0]
records = [
{
name = "ci"
type = "A"
ttl = 300
records = [
"34.24.14.04",
]
},
]
depends_on = [module.zones]
}我选择了一个与PRO不同的环境,所以这个模块除了.在运行地形计划之后我得到..。
Error: Invalid index
on main.tf line 287, in module "records":
287: zone_name = keys(module.zones.this_route53_zone_zone_id)[0]
|----------------
| module.zones.this_route53_zone_zone_id is object with no attributes
The given key does not identify an element in this collection value.我该怎么处理呢?我想在de环境中使用任何值的代码。
发布于 2020-11-05 01:57:27
我们在route53上创建了一个github.com/mineiros-io/terraform-aws-route53 53模块,作为开源terraform库的一部分。
使用此模块的解决方案如下所示:
example.com创建区域zone_id = module.zones.zone["example.com"].zone_id注意:应该以自然的方式解决依赖关系,因此无需在此解决方案中使用depends_on 。如果需要意外的依赖关系,我们还通过使用module_depends_on = [...]为terraform 0.12提供了一种解决方法,这将强制模块内的所有资源依赖。
module "zones" {
source = "mineiros-io/route53/aws"
version = "~> 0.3.0"
# not called 'create' but 'module_enabled' in our modules.
module_enabled = var.environment == "PRO"
# it is possible to create multiple zones at once all sharing the same
# delegation set (nameservers)
name = [
"example.com" ,
]
comment = "example.com (${var.environment})"
tags = merge(var.global_tags, {
environment = var.environment
})
}
module "records" {
source = "mineiros-io/route53/aws"
version = "~> 0.3.0"
module_enabled = var.environment == "PRO"
zone_id = module.zones.zone["example.com"].zone_id
records = [
{
name = "ci"
type = "A"
ttl = 300
records = [
"34.24.14.04",
]
},
]
}在这里看到一些更复杂的例子:github.com/mineiros-io/terraform-aws-route53/tree/master/examples
该计划的内容如下:
# module.records.aws_route53_record.record["a-ci"] will be created
+ resource "aws_route53_record" "record" {
+ allow_overwrite = false
+ fqdn = (known after apply)
+ id = (known after apply)
+ name = "ci"
+ records = [
+ "34.24.14.04",
]
+ ttl = 300
+ type = "A"
+ zone_id = (known after apply)
}
# module.zones.aws_route53_delegation_set.delegation_set[0] will be created
+ resource "aws_route53_delegation_set" "delegation_set" {
+ id = (known after apply)
+ name_servers = (known after apply)
}
# module.zones.aws_route53_zone.zone["example.com"] will be created
+ resource "aws_route53_zone" "zone" {
+ comment = "example.com (PRO)"
+ delegation_set_id = (known after apply)
+ force_destroy = false
+ id = (known after apply)
+ name = "example.com"
+ name_servers = (known after apply)
+ tags = {
+ "Name" = "example.com"
+ "environment" = "PRO"
}
+ zone_id = (known after apply)
}
Plan: 3 to add, 0 to change, 0 to destroy.注意:为了清楚起见,您还可以合并模块的两个调用,并在同一个模块调用中创建区域和记录。我只是拆分了用法,以匹配您的初始示例。
https://stackoverflow.com/questions/64684510
复制相似问题