【发布时间】:2018-12-18 15:11:26
【问题描述】:
我在向我的 LB 侦听器添加证书时遇到问题。这是用于执行此操作的代码(注意这是一段 sn-ps 代码):
global/main.tf
resource "aws_acm_certificate" "demo_cert_east" {
provider = "aws.east"
domain_name = "*.mydomain.com"
validation_method = "DNS"
tags {
Name = "demo certificate"
Environment = "demo"
}
lifecycle {
create_before_destroy = true
}
}
stage/main.tf
data "aws_acm_certificate" "demo_cert" {
domain = "*.mydomain.com"
statuses = ["ISSUED", "PENDING_VALIDATION"]
}
resource "aws_lb_listener" "wfe_demo_ssl" {
load_balancer_arn = "${aws_lb.wfe_demo.arn}"
port = "443"
protocol = "HTTPS"
ssl_policy = "ELBSecurityPolicy-2016-08"
certificate_arn = "${data.aws_acm_certificate.demo_cert.arn}"
default_action {
target_group_arn = "${aws_lb_target_group.wfe_demo.arn}"
type = "forward"
}
}
我已确保这两个资源都位于 aws-east 区域。我收到错误消息:
创建 LB 侦听器时出错:CertificateNotFound:找不到证书“arn:aws:acm:us-east-1:078395932517:certificate/b83ba534-ef9d-4a07-ae13-832695dc8b5a”。
因此数据源正在正确检索证书,但侦听器似乎找不到它。
【问题讨论】:
-
您为什么要使用数据源以及资源来实际创建它?我也很困惑,如果您在这里使用美国东部 1,为什么您在
aws_acm_certificate上有provider = "aws.east"行? -
对不起,我应该澄清一下,这是我的代码的 sn-p,这是相关信息。我在一个文件中定义了资源,以便我可以维护它。然后在另一个目录中我访问创建的证书
-
证书是否经过验证?您不能将非
ISSUED证书附加到负载均衡器。您可能应该从数据源中删除PENDING_VALIDATION状态。 -
@ydaetskcoR 问题是在尝试时没有颁发证书,希望这对其他人有帮助
标签: amazon-web-services amazon-ec2 terraform