Class CapacityProviderStrategyItem
- java.lang.Object
-
- software.amazon.awssdk.services.ecs.model.CapacityProviderStrategyItem
-
- All Implemented Interfaces:
Serializable,SdkPojo,ToCopyableBuilder<CapacityProviderStrategyItem.Builder,CapacityProviderStrategyItem>
@Generated("software.amazon.awssdk:codegen") public final class CapacityProviderStrategyItem extends Object implements SdkPojo, Serializable, ToCopyableBuilder<CapacityProviderStrategyItem.Builder,CapacityProviderStrategyItem>
The details of a capacity provider strategy. A capacity provider strategy can be set when using the RunTaskor CreateCluster APIs or as the default capacity provider strategy for a cluster with the
CreateClusterAPI.Only capacity providers that are already associated with a cluster and have an
ACTIVEorUPDATINGstatus 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 CreateClusterCapacityProvider API operation.
To use a Fargate capacity provider, specify either the
FARGATEorFARGATE_SPOTcapacity providers. The 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.With
FARGATE_SPOT, you can run interruption tolerant tasks at a rate that's discounted compared to theFARGATEprice.FARGATE_SPOTruns tasks on spare compute capacity. When Amazon Web Services needs the capacity back, your tasks are interrupted with a two-minute warning.FARGATE_SPOTsupports Linux tasks with the X86_64 architecture on platform version 1.3.0 or later.FARGATE_SPOTsupports Linux tasks with the ARM64 architecture on platform version 1.4.0 or later.A capacity provider strategy can contain a maximum of 20 capacity providers.
- See Also:
- Serialized Form
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static interfaceCapacityProviderStrategyItem.Builder
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description Integerbase()The base value designates how many tasks, at a minimum, to run on the specified capacity provider for each service.static CapacityProviderStrategyItem.Builderbuilder()StringcapacityProvider()The short name of the capacity provider.booleanequals(Object obj)booleanequalsBySdkFields(Object obj)<T> Optional<T>getValueForField(String fieldName, Class<T> clazz)inthashCode()Map<String,SdkField<?>>sdkFieldNameToField()List<SdkField<?>>sdkFields()static Class<? extends CapacityProviderStrategyItem.Builder>serializableBuilderClass()CapacityProviderStrategyItem.BuildertoBuilder()StringtoString()Returns a string representation of this object.Integerweight()The weight value designates the relative percentage of the total number of tasks launched that should use the specified capacity provider.-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface software.amazon.awssdk.utils.builder.ToCopyableBuilder
copy
-
-
-
-
Method Detail
-
capacityProvider
public final String capacityProvider()
The short name of the capacity provider.
- Returns:
- The short name of the capacity provider.
-
weight
public final Integer weight()
The weight value designates the relative percentage of the total number of tasks launched that should use the specified capacity provider. The
weightvalue is taken into consideration after thebasevalue, if defined, is satisfied.If no
weightvalue is specified, the default value of0is 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 of0can't be used to place tasks. If you specify multiple capacity providers in a strategy that all have a weight of0, anyRunTaskorCreateServiceactions using the capacity provider strategy will fail.Weight value characteristics:
-
Weight is considered after the base value is satisfied
-
The default value is
0if not specified -
The valid range is 0 to 1,000
-
At least one capacity provider must have a weight greater than zero
-
Capacity providers with weight of
0cannot 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
1will split tasks evenly after base requirements are met.Weighted Distribution: If capacityProviderA has weight
1and capacityProviderB has weight4, then for every 1 task on A, 4 tasks will run on B.- Returns:
- The weight value designates the relative percentage of the total number of tasks launched that
should use the specified capacity provider. The
weightvalue is taken into consideration after thebasevalue, if defined, is satisfied.If no
weightvalue is specified, the default value of0is 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 of0can't be used to place tasks. If you specify multiple capacity providers in a strategy that all have a weight of0, anyRunTaskorCreateServiceactions using the capacity provider strategy will fail.Weight value characteristics:
-
Weight is considered after the base value is satisfied
-
The default value is
0if not specified -
The valid range is 0 to 1,000
-
At least one capacity provider must have a weight greater than zero
-
Capacity providers with weight of
0cannot 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
1will split tasks evenly after base requirements are met.Weighted Distribution: If capacityProviderA has weight
1and capacityProviderB has weight4, then for every 1 task on A, 4 tasks will run on B. -
-
-
base
public final Integer 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
0is used.Base value characteristics:
-
Only one capacity provider in a strategy can have a base defined
-
The default value is
0if not specified -
The valid range is 0 to 100,000
-
Base requirements are satisfied first before weight distribution
- Returns:
- 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
0is used.Base value characteristics:
-
Only one capacity provider in a strategy can have a base defined
-
The default value is
0if not specified -
The valid range is 0 to 100,000
-
Base requirements are satisfied first before weight distribution
-
-
-
toBuilder
public CapacityProviderStrategyItem.Builder toBuilder()
- Specified by:
toBuilderin interfaceToCopyableBuilder<CapacityProviderStrategyItem.Builder,CapacityProviderStrategyItem>
-
builder
public static CapacityProviderStrategyItem.Builder builder()
-
serializableBuilderClass
public static Class<? extends CapacityProviderStrategyItem.Builder> serializableBuilderClass()
-
equalsBySdkFields
public final boolean equalsBySdkFields(Object obj)
- Specified by:
equalsBySdkFieldsin interfaceSdkPojo
-
toString
public final String toString()
Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be redacted from this string using a placeholder value.
-
sdkFieldNameToField
public final Map<String,SdkField<?>> sdkFieldNameToField()
- Specified by:
sdkFieldNameToFieldin interfaceSdkPojo
-
-