地形:使用模块自动扩展 ECS 服务



我们有一个用例,想要扩展 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) 使用上述资源创建一个模块,上面每个资源的计数为 10,以便您可以遍历它们。

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

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

最新更新