Terraform:使用模块自动缩放ecs服务

时间:2019-01-05 06:59:40

标签: terraform

我们有一个用例,希望扩展ECS服务。大约有10个服务。我不想在每个服务模块中添加缩放代码。另外,我不想为此创建模块,并在根模块main.tf中为每个服务调用它们。

在下面的代码中,只有少数几个变量会更改示例服务名称,目标组arn等。

resource "aws_appautoscaling_target" "ecs_target" {
  max_capacity       = "${var.max_capacity}"
  min_capacity       = "${var.min_capacity}"
  resource_id        = "service/${var.cluster}/${aws_ecs_service.rc.name}"
  scalable_dimension = "ecs:service:DesiredCount"
  service_namespace  = "ecs"
}

resource "aws_appautoscaling_policy" "ecs_policy" {
  #count              = "${var.auto_scaling_enabled}"
  name               = "rc-ecs-auto-scale"
  policy_type        = "TargetTrackingScaling"
  resource_id        = "service/cluster/${aws_ecs_service.rc.name}"
  scalable_dimension = "ecs:service:DesiredCount"
  service_namespace  = "ecs"

  target_tracking_scaling_policy_configuration {
    predefined_metric_specification {
      predefined_metric_type = "ALBRequestCountPerTarget"

      resource_label = "${var.alb_arn_suffix}/${aws_alb_target_group.rc.arn_suffix}"
    }

    target_value       = "${var.threshold_value_to_scale}"
    scale_in_cooldown  = "${var.scale_in_cooldown}"
    scale_out_cooldown = "${var.scale_out_cooldown}"
  }

  depends_on = ["aws_appautoscaling_target.ecs_target"]
}

实现此目标的最佳方法是什么?

1 个答案:

答案 0 :(得分:0)

您可以使用模块或不使用模块来完成此任务,但是使用模块会更优雅。

1)使用上述资源创建一个模块,上面每个资源的数量为10,这样您就可以遍历它们。

2)使用每个服务的每个参数包含10个值的数组调用模块。

module "services" {
  service_names = []
  capacity = []
  ...
}