AWS CLI를 사용하는 Auto Scaling Plans 예제
다음 코드 예제는 Auto Scaling Plans와 함께 AWS Command Line Interface를 사용하여 작업을 수행하고 일반적인 시나리오를 구현하는 방법을 보여줍니다.
작업은 대규모 프로그램에서 발췌한 코드이며 컨텍스트에 맞춰 실행해야 합니다. 작업은 관련 시나리오의 컨텍스트에 따라 표시되며, 개별 서비스 함수를 직접적으로 호출하는 방법을 보여줍니다.
각 예시에는 전체 소스 코드에 대한 링크가 포함되어 있으며, 여기에서 컨텍스트에 맞춰 코드를 설정하고 실행하는 방법에 대한 지침을 찾을 수 있습니다.
주제
작업
다음 코드 예시에서는 create-scaling-plan
을 사용하는 방법을 보여 줍니다.
- AWS CLI
-
조정 계획을 생성하는 방법
다음
create-scaling-plan
예제에서는 이미 생성된 JSON 파일(이름이 config.json인 파일)을 사용하여my-scaling-plan
이라는 이름의 조정 계획을 생성합니다. 조정 계획의 구조에는my-asg
라는 이름의 Auto Scaling 그룹에 대한 스케일링 지침이 포함되어 있습니다. 이 계획은TagFilters
속성을 애플리케이션 소스로 지정하고 예측 조정 및 동적 조정을 활성화합니다.aws autoscaling-plans create-scaling-plan \ --scaling-plan-name
my-scaling-plan
\ --cli-input-jsonfile://~/config.json
config.json
파일의 콘텐츠:{ "ApplicationSource": { "TagFilters": [ { "Key": "purpose", "Values": [ "my-application" ] } ] }, "ScalingInstructions": [ { "ServiceNamespace": "autoscaling", "ResourceId": "autoScalingGroup/my-asg", "ScalableDimension": "autoscaling:autoScalingGroup:DesiredCapacity", "ScheduledActionBufferTime": 300, "PredictiveScalingMaxCapacityBehavior": "SetForecastCapacityToMaxCapacity", "PredictiveScalingMode": "ForecastAndScale", "PredefinedLoadMetricSpecification": { "PredefinedLoadMetricType": "ASGTotalCPUUtilization" }, "ScalingPolicyUpdateBehavior": "ReplaceExternalPolicies", "MinCapacity": 1, "MaxCapacity": 4, "TargetTrackingConfigurations": [ { "PredefinedScalingMetricSpecification": { "PredefinedScalingMetricType": "ASGAverageCPUUtilization" }, "TargetValue": 50 } ] } ] }
출력:
{ "ScalingPlanVersion": 1 }
자세한 내용은 AWS Auto Scaling 사용 설명서를 참조하세요.
-
API 세부 정보는 AWS CLI 명령 참조의 CreateScalingPlan
을 참조하세요.
-
다음 코드 예시에서는 delete-scaling-plan
을 사용하는 방법을 보여 줍니다.
- AWS CLI
-
조정 계획을 삭제하는 방법
다음
delete-scaling-plan
예제에서는 지정된 조정 계획을 삭제합니다.aws autoscaling-plans delete-scaling-plan \ --scaling-plan-name
my-scaling-plan
\ --scaling-plan-version1
이 명령은 출력을 생성하지 않습니다.
자세한 내용은 AWS Auto Scaling 사용 설명서를 참조하세요.
-
API 세부 정보는 AWS CLI 명령 참조의 DeleteScalingPlan
을 참조하세요.
-
다음 코드 예시에서는 describe-scaling-plan-resources
을 사용하는 방법을 보여 줍니다.
- AWS CLI
-
조정 계획을 위한 확장 가능 리소스를 설명하는 방법
다음
describe-scaling-plan-resources
예제에서는 지정된 조정 계획과 연결된 단일 확장 가능 리소스(Auto Scaling 그룹)에 대한 세부 정보를 표시합니다.aws autoscaling-plans describe-scaling-plan-resources \ --scaling-plan-name
my-scaling-plan
\ --scaling-plan-version1
출력:
{ "ScalingPlanResources": [ { "ScalableDimension": "autoscaling:autoScalingGroup:DesiredCapacity", "ScalingPlanVersion": 1, "ResourceId": "autoScalingGroup/my-asg", "ScalingStatusCode": "Active", "ScalingStatusMessage": "Target tracking scaling policies have been applied to the resource.", "ScalingPolicies": [ { "PolicyName": "AutoScaling-my-asg-b1ab65ae-4be3-4634-bd64-c7471662b251", "PolicyType": "TargetTrackingScaling", "TargetTrackingConfiguration": { "PredefinedScalingMetricSpecification": { "PredefinedScalingMetricType": "ALBRequestCountPerTarget", "ResourceLabel": "app/my-alb/f37c06a68c1748aa/targetgroup/my-target-group/6d4ea56ca2d6a18d" }, "TargetValue": 40.0 } } ], "ServiceNamespace": "autoscaling", "ScalingPlanName": "my-scaling-plan" } ] }
자세한 내용은 AWS Auto Scaling 사용 설명서의 AWS Auto Scaling이란?을 참조하세요.
-
API 세부 정보는 AWS CLI 명령 참조의 DescribeScalingPlanResources
를 참조하세요.
-
다음 코드 예시에서는 describe-scaling-plans
을 사용하는 방법을 보여 줍니다.
- AWS CLI
-
조정 계획을 설명하는 방법
다음
describe-scaling-plans
예제에서는 지정된 조정 계획의 세부 정보를 표시합니다.aws autoscaling-plans describe-scaling-plans \ --scaling-plan-names
scaling-plan-with-asg-and-ddb
출력:
{ "ScalingPlans": [ { "LastMutatingRequestTime": 1565388443.963, "ScalingPlanVersion": 1, "CreationTime": 1565388443.963, "ScalingInstructions": [ { "ScalingPolicyUpdateBehavior": "ReplaceExternalPolicies", "ScalableDimension": "autoscaling:autoScalingGroup:DesiredCapacity", "TargetTrackingConfigurations": [ { "PredefinedScalingMetricSpecification": { "PredefinedScalingMetricType": "ASGAverageCPUUtilization" }, "TargetValue": 50.0, "EstimatedInstanceWarmup": 300, "DisableScaleIn": false } ], "ResourceId": "autoScalingGroup/my-asg", "DisableDynamicScaling": false, "MinCapacity": 1, "ServiceNamespace": "autoscaling", "MaxCapacity": 10 }, { "ScalingPolicyUpdateBehavior": "ReplaceExternalPolicies", "ScalableDimension": "dynamodb:table:ReadCapacityUnits", "TargetTrackingConfigurations": [ { "PredefinedScalingMetricSpecification": { "PredefinedScalingMetricType": "DynamoDBReadCapacityUtilization" }, "TargetValue": 50.0, "ScaleInCooldown": 60, "DisableScaleIn": false, "ScaleOutCooldown": 60 } ], "ResourceId": "table/my-table", "DisableDynamicScaling": false, "MinCapacity": 5, "ServiceNamespace": "dynamodb", "MaxCapacity": 10000 }, { "ScalingPolicyUpdateBehavior": "ReplaceExternalPolicies", "ScalableDimension": "dynamodb:table:WriteCapacityUnits", "TargetTrackingConfigurations": [ { "PredefinedScalingMetricSpecification": { "PredefinedScalingMetricType": "DynamoDBWriteCapacityUtilization" }, "TargetValue": 50.0, "ScaleInCooldown": 60, "DisableScaleIn": false, "ScaleOutCooldown": 60 } ], "ResourceId": "table/my-table", "DisableDynamicScaling": false, "MinCapacity": 5, "ServiceNamespace": "dynamodb", "MaxCapacity": 10000 } ], "ApplicationSource": { "TagFilters": [ { "Values": [ "my-application-id" ], "Key": "application" } ] }, "StatusStartTime": 1565388455.836, "ScalingPlanName": "scaling-plan-with-asg-and-ddb", "StatusMessage": "Scaling plan has been created and applied to all resources.", "StatusCode": "Active" } ] }
자세한 내용은 AWS Auto Scaling 사용 설명서의 AWS Auto Scaling이란?을 참조하세요.
-
API 세부 정보는 AWS CLI 명령 참조의 DescribeScalingPlans
를 참조하세요.
-
다음 코드 예시에서는 get-scaling-plan-resource-forecast-data
을 사용하는 방법을 보여 줍니다.
- AWS CLI
-
로드 예측 데이터를 검색하는 방법
이 예제에서는 지정된 조정 계획과 연결된 확장 가능 리소스(Auto Scaling 그룹)에 대한 로드 예측 데이터를 검색합니다.
aws autoscaling-plans get-scaling-plan-resource-forecast-data \ --scaling-plan-name
my-scaling-plan
\ --scaling-plan-version1
\ --service-namespace"autoscaling"
\ --resource-idautoScalingGroup/my-asg
\ --scalable-dimension"autoscaling:autoScalingGroup:DesiredCapacity"
\ --forecast-data-type"LoadForecast"
\ --start-time"2019-08-30T00:00:00Z"
\ --end-time"2019-09-06T00:00:00Z"
출력:
{ "Datapoints": [...] }
자세한 내용은 AWS Auto Scaling 사용 설명서의 AWS Auto Scaling이란을 참조하세요.
-
API 세부 정보는 AWS CLI 명령 참조의 GetScalingPlanResourceForecastData
를 참조하세요.
-
다음 코드 예시에서는 update-scaling-plan
을 사용하는 방법을 보여 줍니다.
- AWS CLI
-
조정 계획을 업데이트하는 방법
다음
update-scaling-plan
예제에서는 지정된 조정 계획에서 Auto Scaling 그룹에 대한 조정 지표를 수정합니다.aws autoscaling-plans update-scaling-plan \ --scaling-plan-name
my-scaling-plan
\ --scaling-plan-version1
\ --scaling-instructions '{"ScalableDimension":"autoscaling:autoScalingGroup:DesiredCapacity","ResourceId":"autoScalingGroup/my-asg","ServiceNamespace":"autoscaling","TargetTrackingConfigurations":[{"PredefinedScalingMetricSpecification": {"PredefinedScalingMetricType":"ALBRequestCountPerTarget","ResourceLabel":"app/my-alb/f37c06a68c1748aa/targetgroup/my-target-group/6d4ea56ca2d6a18d"},"TargetValue":40.0}],"MinCapacity": 1,"MaxCapacity": 10}
'이 명령은 출력을 생성하지 않습니다.
자세한 내용은 AWS Auto Scaling 사용 설명서의 AWS Auto Scaling이란?을 참조하세요.
-
API 세부 정보는 AWS CLI 명령 참조의 UpdateScalingPlan
을 참조하세요.
-