我有一个模块,它创建子模块,每个子模块都有一个custom_error_response,它位于不同的response_page_path上。
在主模块中我增加了;
custom_error_response = [
{
error_code = "403"
error_caching_min_ttl = "30"
response_code = "200"
response_page_path = "/${var.default_root_object}"
},
]变量default_root_object是:
variable "default_root_object" {
description = "Default root object at origin for CloudFront distribution"
}在子模块中,我在variables.tf中添加了以下内容:
variable "custom_error_response" {
description = "(Optional) - List of one or more custom error response element maps"
type = "list"
default = []
}在每个子模块的main.tf中,我还像这样定义了custom_error_response:
dynamic "custom_error_response" {
for_each = var.custom_error_response
content {
error_caching_min_ttl = lookup(custom_error_response.value, "error_caching_min_ttl", null)
error_code = custom_error_response.value.error_code
response_code = lookup(custom_error_response.value, "response_code", null)
response_page_path = lookup(custom_error_response.value, "response_page_path", null)
}
} 当我运行terraform时,它是可以的,但是当我运行terraform计划时,它给了我相同的错误8次,我已经做了8个子模块。
Error: Invalid value for module argument
on portal_distribution/main.tf line 32, in module "**mainmodule**":
32: custom_error_response = [
33: {
34: error_code = "403"
35: error_caching_min_ttl = "30"
36: response_code = "200"
37: response_page_path = "/${var.default_root_object}"
38: },
39: ]
The given value is not suitable for child module variable
"custom_error_response" defined at
.terraform/modules/**submodule**_portal.**mainmodule**/modules/aws-terraform-cloudfront_s3_origin/variables.tf:302,1-33:
element 0: string required.如何纠正错误?
发布于 2020-10-09 10:54:11
变量的类型是一个列表。事实上,您正在进行地图查找,这意味着您正在尝试使用地图或其他什么。我建议的是:使用一张物体的地图。
如果您需要它是一个var:
variable myinput {
type = map(list(object({
error_caching_min_ttl = string
error_code = number
response_code = number
response_page_path = string
})))
}在我用来在我的机器上证明这一点的代码中,我没有使用var。因此,在for_each所在的地方,只需将变量放在那里,然后用值填充变量。解决方案是使用对象映射。我喜欢地图而不是列表,因为你可以给集合中的每个项目一个描述性的标题。这有助于在州的名字的意思是。
dynamic "custom_error_response" {
for_each = map(
"descriptiveTitleForThis", {
error_caching_min_ttl = "60"
error_code = 403
response_code = 11
response_page_path = "page1"
},
"551directToPage2", {
error_caching_min_ttl = "60"
error_code = 551
response_code = 10
response_page_path = "page2"
}
)
content {
error_caching_min_ttl = custom_error_response.value.error_caching_min_ttl
error_code = custom_error_response.value.error_code
response_code = custom_error_response.value.response_code
response_page_path = custom_error_response.value.response_page_path
}
}如果你想要的话,我的完整代码如下:
provider aws {
profile = "myprofile"
region = "us-west-2"
}
resource "aws_s3_bucket" "b" {
bucket = "mybucket"
acl = "private"
tags = {
Name = "My bucket"
}
}
locals {
s3_origin_id = "myS3Origin"
}
resource "aws_cloudfront_distribution" "s3_distribution" {
enabled = true
origin {
domain_name = aws_s3_bucket.b.bucket_regional_domain_name
origin_id = local.s3_origin_id
}
default_cache_behavior {
allowed_methods = ["DELETE", "GET", "HEAD", "OPTIONS", "PATCH", "POST", "PUT"]
cached_methods = ["GET", "HEAD"]
target_origin_id = local.s3_origin_id
forwarded_values {
query_string = false
cookies {
forward = "none"
}
}
viewer_protocol_policy = "allow-all"
min_ttl = 0
default_ttl = 3600
max_ttl = 86400
}
restrictions {
geo_restriction {
restriction_type = "whitelist"
locations = ["US", "CA", "GB", "DE"]
}
}
viewer_certificate {
cloudfront_default_certificate = true
}
dynamic "custom_error_response" {
for_each = map(
"descriptiveTitleForThis", {
error_caching_min_ttl = "60"
error_code = 403
response_code = 11
response_page_path = "page1"
},
"551directToPage2", {
error_caching_min_ttl = "60"
error_code = 551
response_code = 10
response_page_path = "page2"
},
"552directToPage3", {
error_caching_min_ttl = "60"
error_code = 552
response_code = 12
response_page_path = "page3"
},
"553directToPage4", {
error_caching_min_ttl = "60"
error_code = 553
response_code = 13
response_page_path = "page4"
},
)
content {
error_caching_min_ttl = custom_error_response.value.error_caching_min_ttl
error_code = custom_error_response.value.error_code
response_code = custom_error_response.value.response_code
response_page_path = custom_error_response.value.response_page_path
}
}
}编辑:我忘了打印计划。
Terraform will perform the following actions:
# aws_cloudfront_distribution.s3_distribution will be created
+ resource "aws_cloudfront_distribution" "s3_distribution" {
<..ommitted for brevity...>
+ custom_error_response {
+ error_caching_min_ttl = 60
+ error_code = 403
+ response_code = 11
+ response_page_path = "page1"
}
+ custom_error_response {
+ error_caching_min_ttl = 60
+ error_code = 551
+ response_code = 10
+ response_page_path = "page2"
}
+ custom_error_response {
+ error_caching_min_ttl = 60
+ error_code = 552
+ response_code = 12
+ response_page_path = "page3"
}
+ custom_error_response {
+ error_caching_min_ttl = 60
+ error_code = 553
+ response_code = 13
+ response_page_path = "page4"
}
<..ommitted for brevity...>
}
# aws_s3_bucket.b will be created
+ resource "aws_s3_bucket" "b" {
<..ommitted for brevity...>
}
Plan: 2 to add, 0 to change, 0 to destroy.terraform versionTerraform v0.12.20
https://stackoverflow.com/questions/64218196
复制相似问题