Я пытаюсь создать NLB с помощью Terraform v0.11.0 (мое приложение не использует HTTP, поэтому я не могу использовать ALB). Заглянув в документацию Hashcorp, я смог создать следующий код:
resource "aws_lb" "lb" {
name = "test"
internal = false
enable_deletion_protection = true
load_balancer_type = "network"
ip_address_type = "ipv4"
subnet_mapping {
subnet_id = "${data.aws_subnet.sn-app-1.id}"
allocation_id = "${aws_eip.eip-1.id}"
}
subnet_mapping {
subnet_id = "${data.aws_subnet.sn-app-2.id}"
allocation_id = "${aws_eip.eip-2.id}"
}
}
resource "aws_lb_target_group" "lbtg" {
name = "test"
port = "8080"
protocol = "TCP"
vpc_id = "${data.aws_vpc.vpc.id}"
deregistration_delay = "300"
health_check {
interval = "300"
port = "8080"
protocol = "TCP"
timeout = "10"
healthy_threshold = "10"
unhealthy_threshold= "10"
}
}
resource "aws_lb_listener" "front_end" {
load_balancer_arn = "${aws_lb.lb.arn}"
port = "8080"
protocol = "TCP"
default_action {
target_group_arn = "${aws_lb_target_group.lbtg.arn}"
type = "forward"
}
}
resource "aws_autoscaling_group" "asg" {
name = "test"
vpc_zone_identifier = ["${data.aws_subnet.sn-app-1.id}","${data.aws_subnet.sn-app-2.id}"]
min_size = 1
desired_capacity = 1
max_size = 3
launch_configuration = "${aws_launch_configuration.lc.name}"
load_balancers = ["${aws_lb.lb.name}"]
default_cooldown= 180
health_check_grace_period = 180
termination_policies = ["ClosestToNextInstanceHour", "NewestInstance"]
}
я бегу terraform init
и terraform plan -out=plan.json
и все идет хорошо, но после пробега terraform apply plan.json
, Terraform потратит некоторое время на создание AutoScaling Group и выдаст что-то вроде этого:
aws_ecs_service.ecss: произошла 1 ошибка (и):
aws_ecs_service.ecss: InvalidParameterException: целевая группа с targetGroupArn arn: aws: elasticloadbalancing: us-east-1: xxxxxx: targetgroup / test / xxxxxx не имеет связанного балансировщика нагрузки. код состояния: 400, идентификатор запроса: b2565334-da9a-11e7-ab5a-8f0bfc9ecd99 "test"
aws_autoscaling_group.asg: 1 ошибка (и):
aws_autoscaling_group.asg: Ошибка при создании AutoScaling Group: ValidationError: Предоставленные балансировщики нагрузки могут быть недействительными. Убедитесь, что они существуют, и попробуйте еще раз. код состояния: 400, идентификатор запроса: cf2d4ac6-da9a-11e7-950f-050f1f0711f8
Как связать целевую группу с LB? И почему предоставленный Load Balancer может не подходить для AutoScaling Group?
Попробуйте использовать target_group_arns
вариант на ПГС.
resource "aws_autoscaling_group" "asg" {
name = "test"
vpc_zone_identifier = ["${data.aws_subnet.sn-app-1.id}","${data.aws_subnet.sn-app-2.id}"]
min_size = 1
desired_capacity = 1
max_size = 3
launch_configuration = "${aws_launch_configuration.lc.name}"
target_group_arns = ["${aws_lb_target_group.lbtg.arn}"]
default_cooldown= 180
health_check_grace_period = 180
termination_policies = ["ClosestToNextInstanceHour", "NewestInstance"]
}