在 Terraform 中,AWS ACM Certificate 需要通过 DNS 验证来验证证书的有效性。在申请证书时,需要为每个要验证的域名提供一个验证选项对象。这些对象在 Terraform 中通过 Aws_acm_certificate.app_cert.domain_validation_options 进行定义。
然而,在 Terraform 配置文件中,这些选项对象的值通常需要在应用后才能获得,因为需要获得验证记录的特定信息。这种情况下,可以使用 Terraform 的 data源来获取这些信息,并将其用于定义域名验证选项对象。
以下是一个示例,演示如何在 Terraform 中使用 data源来获取 DNS 记录中的值,并将其用于定义 AWS ACM Certificate 的域名验证选项对象:
data "aws_route53_zone" "example" {
name = "example.com."
}
resource "aws_acm_certificate" "app_cert" {
domain_name = "example.com"
validation_method = "DNS"
lifecycle {
create_before_destroy = true
}
}
data "aws_route53_record" "example" {
zone_id = data.aws_route53_zone.example.id
name = aws_acm_certificate.app_cert.domain_validation_options[0].resource_record_name
type = aws_acm_certificate.app_cert.domain_validation_options[0].resource_record_type
}
resource "aws_acm_certificate_validation" "app_cert_validation" {
certificate_arn = aws_acm_certificate.app_cert.arn
validation_record_fqdns = [data.aws_route53_record.example.fqdn]
}
在这个示例中,我们首先定义了一个 data 源 aws_route53_zone 来获取 example.com 的 Route53 区域的 ID。我们还定义了一个 AWS ACM 证书 app_cert,并将其设置为 DNS 验证模式。为了支持证书验证,我们启用了生命周期策略,在应用新的证