如何设置 ECS 服务最小和最大任务
Posted
技术标签:
【中文标题】如何设置 ECS 服务最小和最大任务【英文标题】:How to set ECS Service minimum & maximum tasks 【发布时间】:2019-04-05 06:40:04 【问题描述】:如何通过API调用设置ECS服务的最小和最大任务数?我知道您可以通过以下 api 设置所需的任务数,但我没有看到任何地方可以设置最小和最大任务?我错过了什么吗?我正在使用 php API,但这里的任何见解都会有所帮助。
https://docs.aws.amazon.com/aws-sdk-php/v3/api/api-ecs-2014-11-13.html#updateservice
【问题讨论】:
【参考方案1】:对于那些寻找 CLI 示例的人,
aws application-autoscaling \
register-scalable-target \
--service-namespace ecs \
--resource-id service/cluster-name/service-name \
--scalable-dimension ecs:service:DesiredCount \
--min-capacity 2 \
--max-capacity 4
【讨论】:
【参考方案2】:我的理解是,只能使用 ECS 服务的 Auto Scaling 策略设置最小值和最大值。 https://docs.aws.amazon.com/AmazonECS/latest/developerguide/service-auto-scaling.html。 您需要创建 Auto Scaling 策略来设置这些。
通过结合使用 Amazon ECS、CloudWatch 和 Application Auto Scaling API,Service Auto Scaling 成为可能。
在您的情况下,仅使用 Application AutoScaling API,调用 registerScalableTarget 方法就足够了。这是示例。
https://docs.aws.amazon.com/aws-sdk-php/v3/api/class-Aws.ApplicationAutoScaling.ApplicationAutoScalingClient.html
$result = $client->registerScalableTarget([
'MaxCapacity' => 20,
'MinCapacity' => 2,
'ResourceId' => 'service/default/sample-webapp', // REQUIRED
'RoleARN' => 'arn:aws:iam::012345678910:role/ApplicationAutoscalingECSRole',
'ScalableDimension' => 'ecs:service:DesiredCount', // REQUIRED
'ServiceNamespace' => 'ecs', // REQUIRED
]);
【讨论】:
我有自动缩放工作,问题是我不知道如何通过 API 调用更新最小和最大任务数。我只能通过在线控制台更新最小值和最大值。如果您知道如何执行此操作,能否提供 API 调用的链接? @BlaneTownsend 我已经用 PHP SDK 示例编辑了我的答案。以上是关于如何设置 ECS 服务最小和最大任务的主要内容,如果未能解决你的问题,请参考以下文章