This is the new AWS CloudFormation Template Reference Guide. Please update your bookmarks and links. For help getting started with CloudFormation, see the AWS CloudFormation User Guide.
AWS::ECS::Service CapacityProviderStrategyItem
The details of a capacity provider strategy. A capacity provider strategy can be set
when using the RunTask
or CreateService
APIs or as the default
capacity provider strategy for a cluster with the CreateCluster
API.
Only capacity providers that are already associated with a cluster and have an
ACTIVE
or UPDATING
status can be used in a capacity provider
strategy. The PutClusterCapacityProviders
API is used to associate a capacity
provider with a cluster.
If specifying a capacity provider that uses an Auto Scaling group, the capacity provider
must already be created. New Auto Scaling group capacity providers can be created with the
CreateCapacityProvider
API operation.
To use an AWS Fargate capacity provider, specify either the
FARGATE
or FARGATE_SPOT
capacity providers. The AWS Fargate capacity providers are available to all accounts and only need to
be associated with a cluster to be used in a capacity provider strategy.
Syntax
To declare this entity in your AWS CloudFormation template, use the following syntax:
JSON
{ "Base" :
Integer
, "CapacityProvider" :String
, "Weight" :Integer
}
YAML
Base:
Integer
CapacityProvider:String
Weight:Integer
Properties
Base
-
The base value designates how many tasks, at a minimum, to run on the specified capacity provider for each service. Only one capacity provider in a capacity provider strategy can have a base defined. If no value is specified, the default value of
0
is used.Base value characteristics:
-
Only one capacity provider in a strategy can have a base defined
-
Default value is
0
if not specified -
Valid range: 0 to 100,000
-
Base requirements are satisfied first before weight distribution
Required: No
Type: Integer
Minimum:
0
Maximum:
100000
Update requires: No interruption
-
CapacityProvider
-
The short name of the capacity provider.
Required: No
Type: String
Update requires: No interruption
Weight
-
The weight value designates the relative percentage of the total number of tasks launched that should use the specified capacity provider. The
weight
value is taken into consideration after thebase
value, if defined, is satisfied.If no
weight
value is specified, the default value of0
is used. When multiple capacity providers are specified within a capacity provider strategy, at least one of the capacity providers must have a weight value greater than zero and any capacity providers with a weight of0
can't be used to place tasks. If you specify multiple capacity providers in a strategy that all have a weight of0
, anyRunTask
orCreateService
actions using the capacity provider strategy will fail.Weight value characteristics:
-
Weight is considered after the base value is satisfied
-
Default value is
0
if not specified -
Valid range: 0 to 1,000
-
At least one capacity provider must have a weight greater than zero
-
Capacity providers with weight of
0
cannot place tasks
Task distribution logic:
-
Base satisfaction: The minimum number of tasks specified by the base value are placed on that capacity provider
-
Weight distribution: After base requirements are met, additional tasks are distributed according to weight ratios
Examples:
Equal Distribution: Two capacity providers both with weight
1
will split tasks evenly after base requirements are met.Weighted Distribution: If capacityProviderA has weight
1
and capacityProviderB has weight4
, then for every 1 task on A, 4 tasks will run on B.Required: No
Type: Integer
Minimum:
0
Maximum:
1000
Update requires: No interruption
-