OLe*_*ACH 5 amazon-web-services amazon-ecs autoscaling terraform
我是 Terraform 和 ECS 的新手,我正在使用此示例创建一个 ECS EC2 类型集群,该集群将自动扩展并使用应用程序负载均衡器。
我的问题是:这段代码片段如何在 main.tf
resource "aws_ecs_service" "test" {
name = "tf-example-ecs-ghost"
cluster = "${aws_ecs_cluster.main.id}"
task_definition = "${aws_ecs_task_definition.ghost.arn}"
desired_count = "${var.service_desired}"
iam_role = "${aws_iam_role.ecs_service.name}"
load_balancer {
target_group_arn = "${aws_alb_target_group.test.id}"
container_name = "ghost"
container_port = "2368"
}
depends_on = [
"aws_iam_role_policy.ecs_service",
"aws_alb_listener.front_end",
]
}
Run Code Online (Sandbox Code Playgroud)
连接到资源aws_autoscaling_group.app
:
resource "aws_autoscaling_group" "app" {
name = "tf-test-asg"
vpc_zone_identifier = ["${aws_subnet.main.*.id}"]
min_size = "${var.asg_min}"
max_size = "${var.asg_max}"
desired_capacity = "${var.asg_desired}"
launch_configuration = "${aws_launch_configuration.app.name}"
}
Run Code Online (Sandbox Code Playgroud)
由于aws_ecs_service
资源定义中没有指向资源的插值变量,ECS 服务定义如何知道在哪里可以找到此自动缩放组aws_autoscaling_group
?它引用了一个目标组,但目标组不引用一个自动缩放组。这就是为什么我感到困惑,因为资源“ecs-service”和资源“aws-autoscaling”之间没有明显的参考。或者也许代码丢失了?如果可能,请提供详尽的解释。
事实并非如此。
ECS 服务在 ECS 集群上进行调度,ECS 集群是实例的逻辑分组,可以是 EC2 或 Fargate(甚至不在具有ECS Anywhere的 AWS 上!),也可以是混合的。
如果要将 EC2 实例加入 ECS 集群,则需要安装 ECS 代理,将其配置为加入正确的集群,并提供实例所需的 IAM 权限,以便能够与 ECS 交互。您可以使用独立 EC2 实例或自动扩展组来执行此操作。
对于目标组,负载均衡器通过这种方式知道将流量发送到哪些对象。对于直接 EC2 实例,您可以通过某种方式向目标组注册 EC2 实例。通过 ECS 服务,可以将这些服务配置为向目标组注册服务中的所有任务。然后,当应发送到目标组的流量到达负载均衡器时,该流量将被发送到相关的 ECS 任务。请注意,负载均衡器可以有多个目标组,这些目标组具有不同的负载均衡器侦听器规则,配置为将流量发送到不同的目标组(或执行固定响应或重定向等),以便负载均衡器可以支持多个 ECS 服务。
归档时间: |
|
查看次数: |
1121 次 |
最近记录: |