【发布时间】:2019-10-09 23:12:11
【问题描述】:
尝试更改现有 ALB 规则中的主机名时,总是出错:
“创建 LB 侦听器规则时出错:PriorityInUse: Priority '40' is current in use”
尝试了来自 here 的建议,但没有任何帮助。尝试不为 TargetGroup 指定名称,使用 create_before_destroy,名称的随机字符串等。Terraform 版本 0.10.7,AWS 提供商 1.54.0(也尝试过 2.10.0)
在后续应用 Terraform 时,将应用更改。
TF 配置:
resource "aws_lb_listener_rule" "rule1" {
depends_on = ["aws_lb_target_group.tg1"]
lifecycle {
create_before_destroy = true
}
listener_arn = "${aws_lb_listener.listener.arn}"
priority = "40"
action {
type = "forward"
target_group_arn = "${aws_lb_target_group.tg1.id}"
}
condition {
field = "host-header"
values = ["www.hostname.com"]
}
condition {
field = "path-pattern"
values = ["/STATIC"]
}
}
resource "aws_lb_target_group" "tg1" {
lifecycle {
create_before_destroy = true
}
port = "443"
protocol = "HTTPS"
vpc_id = "${var.vpc_id}"
health_check {
interval = "10"
path = "/"
port= "443"
protocol = "HTTPS"
timeout = "9"
healthy_threshold = "5"
unhealthy_threshold = "3"
}
tags {
Name = "${terraform.workspace}-service1"
}
}
我希望一旦您更改 ALB 规则中的主机名,Terraform 将毫无问题地处理该更改,但看起来它正在尝试使用新主机名但具有相同的优先级编号重新创建 ALB 规则,因此它失败了。再次运行 terraform apply 后,它会进行更改。
可能有一些变通方法来检查现有 ALB 规则优先级名称并指定一个新的/不同的,但这应该由 Terraform 本地处理,否则我们需要跟踪优先级编号以避免冲突。
有人遇到过同样的问题并以某种方式解决了吗?
提前致谢。
【问题讨论】:
标签: terraform terraform-provider-aws