@Generated(value="com.amazonaws:aws-java-sdk-code-generator") public class InstancesDistribution extends Object implements Serializable, Cloneable
Describes an instances distribution for an Auto Scaling group with a MixedInstancesPolicy.
The instances distribution specifies the distribution of On-Demand Instances and Spot Instances, the maximum price to pay for Spot Instances, and how the Auto Scaling group allocates instance types to fulfill On-Demand and Spot capacity.
When you update SpotAllocationStrategy
, SpotInstancePools
, or SpotMaxPrice
,
this update action does not deploy any changes across the running Amazon EC2 instances in the group. Your existing
Spot Instances continue to run as long as the maximum price for those instances is higher than the current Spot
price. When scale out occurs, Amazon EC2 Auto Scaling launches instances based on the new settings. When scale in
occurs, Amazon EC2 Auto Scaling terminates instances according to the group's termination policies.
Constructor and Description |
---|
InstancesDistribution() |
Modifier and Type | Method and Description |
---|---|
InstancesDistribution |
clone() |
boolean |
equals(Object obj) |
String |
getOnDemandAllocationStrategy()
Indicates how to allocate instance types to fulfill On-Demand capacity.
|
Integer |
getOnDemandBaseCapacity()
The minimum amount of the Auto Scaling group's capacity that must be fulfilled by On-Demand Instances.
|
Integer |
getOnDemandPercentageAboveBaseCapacity()
Controls the percentages of On-Demand Instances and Spot Instances for your additional capacity beyond
OnDemandBaseCapacity . |
String |
getSpotAllocationStrategy()
Indicates how to allocate instances across Spot Instance pools.
|
Integer |
getSpotInstancePools()
The number of Spot Instance pools across which to allocate your Spot Instances.
|
String |
getSpotMaxPrice()
The maximum price per unit hour that you are willing to pay for a Spot Instance.
|
int |
hashCode() |
void |
setOnDemandAllocationStrategy(String onDemandAllocationStrategy)
Indicates how to allocate instance types to fulfill On-Demand capacity.
|
void |
setOnDemandBaseCapacity(Integer onDemandBaseCapacity)
The minimum amount of the Auto Scaling group's capacity that must be fulfilled by On-Demand Instances.
|
void |
setOnDemandPercentageAboveBaseCapacity(Integer onDemandPercentageAboveBaseCapacity)
Controls the percentages of On-Demand Instances and Spot Instances for your additional capacity beyond
OnDemandBaseCapacity . |
void |
setSpotAllocationStrategy(String spotAllocationStrategy)
Indicates how to allocate instances across Spot Instance pools.
|
void |
setSpotInstancePools(Integer spotInstancePools)
The number of Spot Instance pools across which to allocate your Spot Instances.
|
void |
setSpotMaxPrice(String spotMaxPrice)
The maximum price per unit hour that you are willing to pay for a Spot Instance.
|
String |
toString()
Returns a string representation of this object.
|
InstancesDistribution |
withOnDemandAllocationStrategy(String onDemandAllocationStrategy)
Indicates how to allocate instance types to fulfill On-Demand capacity.
|
InstancesDistribution |
withOnDemandBaseCapacity(Integer onDemandBaseCapacity)
The minimum amount of the Auto Scaling group's capacity that must be fulfilled by On-Demand Instances.
|
InstancesDistribution |
withOnDemandPercentageAboveBaseCapacity(Integer onDemandPercentageAboveBaseCapacity)
Controls the percentages of On-Demand Instances and Spot Instances for your additional capacity beyond
OnDemandBaseCapacity . |
InstancesDistribution |
withSpotAllocationStrategy(String spotAllocationStrategy)
Indicates how to allocate instances across Spot Instance pools.
|
InstancesDistribution |
withSpotInstancePools(Integer spotInstancePools)
The number of Spot Instance pools across which to allocate your Spot Instances.
|
InstancesDistribution |
withSpotMaxPrice(String spotMaxPrice)
The maximum price per unit hour that you are willing to pay for a Spot Instance.
|
public void setOnDemandAllocationStrategy(String onDemandAllocationStrategy)
Indicates how to allocate instance types to fulfill On-Demand capacity.
The only valid value is prioritized
, which is also the default value. This strategy uses the order
of instance type overrides for the LaunchTemplate to define the launch priority of each instance type. The
first instance type in the array is prioritized higher than the last. If all your On-Demand capacity cannot be
fulfilled using your highest priority instance, then the Auto Scaling groups launches the remaining capacity
using the second priority instance type, and so on.
onDemandAllocationStrategy
- Indicates how to allocate instance types to fulfill On-Demand capacity.
The only valid value is prioritized
, which is also the default value. This strategy uses the
order of instance type overrides for the LaunchTemplate to define the launch priority of each
instance type. The first instance type in the array is prioritized higher than the last. If all your
On-Demand capacity cannot be fulfilled using your highest priority instance, then the Auto Scaling groups
launches the remaining capacity using the second priority instance type, and so on.
public String getOnDemandAllocationStrategy()
Indicates how to allocate instance types to fulfill On-Demand capacity.
The only valid value is prioritized
, which is also the default value. This strategy uses the order
of instance type overrides for the LaunchTemplate to define the launch priority of each instance type. The
first instance type in the array is prioritized higher than the last. If all your On-Demand capacity cannot be
fulfilled using your highest priority instance, then the Auto Scaling groups launches the remaining capacity
using the second priority instance type, and so on.
The only valid value is prioritized
, which is also the default value. This strategy uses the
order of instance type overrides for the LaunchTemplate to define the launch priority of each
instance type. The first instance type in the array is prioritized higher than the last. If all your
On-Demand capacity cannot be fulfilled using your highest priority instance, then the Auto Scaling groups
launches the remaining capacity using the second priority instance type, and so on.
public InstancesDistribution withOnDemandAllocationStrategy(String onDemandAllocationStrategy)
Indicates how to allocate instance types to fulfill On-Demand capacity.
The only valid value is prioritized
, which is also the default value. This strategy uses the order
of instance type overrides for the LaunchTemplate to define the launch priority of each instance type. The
first instance type in the array is prioritized higher than the last. If all your On-Demand capacity cannot be
fulfilled using your highest priority instance, then the Auto Scaling groups launches the remaining capacity
using the second priority instance type, and so on.
onDemandAllocationStrategy
- Indicates how to allocate instance types to fulfill On-Demand capacity.
The only valid value is prioritized
, which is also the default value. This strategy uses the
order of instance type overrides for the LaunchTemplate to define the launch priority of each
instance type. The first instance type in the array is prioritized higher than the last. If all your
On-Demand capacity cannot be fulfilled using your highest priority instance, then the Auto Scaling groups
launches the remaining capacity using the second priority instance type, and so on.
public void setOnDemandBaseCapacity(Integer onDemandBaseCapacity)
The minimum amount of the Auto Scaling group's capacity that must be fulfilled by On-Demand Instances. This base portion is provisioned first as your group scales.
Default if not set is 0. If you leave it set to 0, On-Demand Instances are launched as a percentage of the Auto
Scaling group's desired capacity, per the OnDemandPercentageAboveBaseCapacity
setting.
An update to this setting means a gradual replacement of instances to maintain the specified number of On-Demand Instances for your base capacity. When replacing instances, Amazon EC2 Auto Scaling launches new instances before terminating the old ones.
onDemandBaseCapacity
- The minimum amount of the Auto Scaling group's capacity that must be fulfilled by On-Demand Instances.
This base portion is provisioned first as your group scales.
Default if not set is 0. If you leave it set to 0, On-Demand Instances are launched as a percentage of the
Auto Scaling group's desired capacity, per the OnDemandPercentageAboveBaseCapacity
setting.
An update to this setting means a gradual replacement of instances to maintain the specified number of On-Demand Instances for your base capacity. When replacing instances, Amazon EC2 Auto Scaling launches new instances before terminating the old ones.
public Integer getOnDemandBaseCapacity()
The minimum amount of the Auto Scaling group's capacity that must be fulfilled by On-Demand Instances. This base portion is provisioned first as your group scales.
Default if not set is 0. If you leave it set to 0, On-Demand Instances are launched as a percentage of the Auto
Scaling group's desired capacity, per the OnDemandPercentageAboveBaseCapacity
setting.
An update to this setting means a gradual replacement of instances to maintain the specified number of On-Demand Instances for your base capacity. When replacing instances, Amazon EC2 Auto Scaling launches new instances before terminating the old ones.
Default if not set is 0. If you leave it set to 0, On-Demand Instances are launched as a percentage of
the Auto Scaling group's desired capacity, per the OnDemandPercentageAboveBaseCapacity
setting.
An update to this setting means a gradual replacement of instances to maintain the specified number of On-Demand Instances for your base capacity. When replacing instances, Amazon EC2 Auto Scaling launches new instances before terminating the old ones.
public InstancesDistribution withOnDemandBaseCapacity(Integer onDemandBaseCapacity)
The minimum amount of the Auto Scaling group's capacity that must be fulfilled by On-Demand Instances. This base portion is provisioned first as your group scales.
Default if not set is 0. If you leave it set to 0, On-Demand Instances are launched as a percentage of the Auto
Scaling group's desired capacity, per the OnDemandPercentageAboveBaseCapacity
setting.
An update to this setting means a gradual replacement of instances to maintain the specified number of On-Demand Instances for your base capacity. When replacing instances, Amazon EC2 Auto Scaling launches new instances before terminating the old ones.
onDemandBaseCapacity
- The minimum amount of the Auto Scaling group's capacity that must be fulfilled by On-Demand Instances.
This base portion is provisioned first as your group scales.
Default if not set is 0. If you leave it set to 0, On-Demand Instances are launched as a percentage of the
Auto Scaling group's desired capacity, per the OnDemandPercentageAboveBaseCapacity
setting.
An update to this setting means a gradual replacement of instances to maintain the specified number of On-Demand Instances for your base capacity. When replacing instances, Amazon EC2 Auto Scaling launches new instances before terminating the old ones.
public void setOnDemandPercentageAboveBaseCapacity(Integer onDemandPercentageAboveBaseCapacity)
Controls the percentages of On-Demand Instances and Spot Instances for your additional capacity beyond
OnDemandBaseCapacity
.
Default if not set is 100. If you leave it set to 100, the percentages are 100% for On-Demand Instances and 0% for Spot Instances.
An update to this setting means a gradual replacement of instances to maintain the percentage of On-Demand Instances for your additional capacity above the base capacity. When replacing instances, Amazon EC2 Auto Scaling launches new instances before terminating the old ones.
Valid Range: Minimum value of 0. Maximum value of 100.
onDemandPercentageAboveBaseCapacity
- Controls the percentages of On-Demand Instances and Spot Instances for your additional capacity beyond
OnDemandBaseCapacity
.
Default if not set is 100. If you leave it set to 100, the percentages are 100% for On-Demand Instances and 0% for Spot Instances.
An update to this setting means a gradual replacement of instances to maintain the percentage of On-Demand Instances for your additional capacity above the base capacity. When replacing instances, Amazon EC2 Auto Scaling launches new instances before terminating the old ones.
Valid Range: Minimum value of 0. Maximum value of 100.
public Integer getOnDemandPercentageAboveBaseCapacity()
Controls the percentages of On-Demand Instances and Spot Instances for your additional capacity beyond
OnDemandBaseCapacity
.
Default if not set is 100. If you leave it set to 100, the percentages are 100% for On-Demand Instances and 0% for Spot Instances.
An update to this setting means a gradual replacement of instances to maintain the percentage of On-Demand Instances for your additional capacity above the base capacity. When replacing instances, Amazon EC2 Auto Scaling launches new instances before terminating the old ones.
Valid Range: Minimum value of 0. Maximum value of 100.
OnDemandBaseCapacity
.
Default if not set is 100. If you leave it set to 100, the percentages are 100% for On-Demand Instances and 0% for Spot Instances.
An update to this setting means a gradual replacement of instances to maintain the percentage of On-Demand Instances for your additional capacity above the base capacity. When replacing instances, Amazon EC2 Auto Scaling launches new instances before terminating the old ones.
Valid Range: Minimum value of 0. Maximum value of 100.
public InstancesDistribution withOnDemandPercentageAboveBaseCapacity(Integer onDemandPercentageAboveBaseCapacity)
Controls the percentages of On-Demand Instances and Spot Instances for your additional capacity beyond
OnDemandBaseCapacity
.
Default if not set is 100. If you leave it set to 100, the percentages are 100% for On-Demand Instances and 0% for Spot Instances.
An update to this setting means a gradual replacement of instances to maintain the percentage of On-Demand Instances for your additional capacity above the base capacity. When replacing instances, Amazon EC2 Auto Scaling launches new instances before terminating the old ones.
Valid Range: Minimum value of 0. Maximum value of 100.
onDemandPercentageAboveBaseCapacity
- Controls the percentages of On-Demand Instances and Spot Instances for your additional capacity beyond
OnDemandBaseCapacity
.
Default if not set is 100. If you leave it set to 100, the percentages are 100% for On-Demand Instances and 0% for Spot Instances.
An update to this setting means a gradual replacement of instances to maintain the percentage of On-Demand Instances for your additional capacity above the base capacity. When replacing instances, Amazon EC2 Auto Scaling launches new instances before terminating the old ones.
Valid Range: Minimum value of 0. Maximum value of 100.
public void setSpotAllocationStrategy(String spotAllocationStrategy)
Indicates how to allocate instances across Spot Instance pools.
If the allocation strategy is lowest-price
, the Auto Scaling group launches instances using the Spot
pools with the lowest price, and evenly allocates your instances across the number of Spot pools that you
specify. If the allocation strategy is capacity-optimized
, the Auto Scaling group launches instances
using Spot pools that are optimally chosen based on the available Spot capacity.
The default Spot allocation strategy for calls that you make through the API, the AWS CLI, or the AWS SDKs is
lowest-price
. The default Spot allocation strategy for the AWS Management Console is
capacity-optimized
.
Valid values: lowest-price
| capacity-optimized
spotAllocationStrategy
- Indicates how to allocate instances across Spot Instance pools.
If the allocation strategy is lowest-price
, the Auto Scaling group launches instances using
the Spot pools with the lowest price, and evenly allocates your instances across the number of Spot pools
that you specify. If the allocation strategy is capacity-optimized
, the Auto Scaling group
launches instances using Spot pools that are optimally chosen based on the available Spot capacity.
The default Spot allocation strategy for calls that you make through the API, the AWS CLI, or the AWS SDKs
is lowest-price
. The default Spot allocation strategy for the AWS Management Console is
capacity-optimized
.
Valid values: lowest-price
| capacity-optimized
public String getSpotAllocationStrategy()
Indicates how to allocate instances across Spot Instance pools.
If the allocation strategy is lowest-price
, the Auto Scaling group launches instances using the Spot
pools with the lowest price, and evenly allocates your instances across the number of Spot pools that you
specify. If the allocation strategy is capacity-optimized
, the Auto Scaling group launches instances
using Spot pools that are optimally chosen based on the available Spot capacity.
The default Spot allocation strategy for calls that you make through the API, the AWS CLI, or the AWS SDKs is
lowest-price
. The default Spot allocation strategy for the AWS Management Console is
capacity-optimized
.
Valid values: lowest-price
| capacity-optimized
If the allocation strategy is lowest-price
, the Auto Scaling group launches instances using
the Spot pools with the lowest price, and evenly allocates your instances across the number of Spot pools
that you specify. If the allocation strategy is capacity-optimized
, the Auto Scaling group
launches instances using Spot pools that are optimally chosen based on the available Spot capacity.
The default Spot allocation strategy for calls that you make through the API, the AWS CLI, or the AWS
SDKs is lowest-price
. The default Spot allocation strategy for the AWS Management Console is
capacity-optimized
.
Valid values: lowest-price
| capacity-optimized
public InstancesDistribution withSpotAllocationStrategy(String spotAllocationStrategy)
Indicates how to allocate instances across Spot Instance pools.
If the allocation strategy is lowest-price
, the Auto Scaling group launches instances using the Spot
pools with the lowest price, and evenly allocates your instances across the number of Spot pools that you
specify. If the allocation strategy is capacity-optimized
, the Auto Scaling group launches instances
using Spot pools that are optimally chosen based on the available Spot capacity.
The default Spot allocation strategy for calls that you make through the API, the AWS CLI, or the AWS SDKs is
lowest-price
. The default Spot allocation strategy for the AWS Management Console is
capacity-optimized
.
Valid values: lowest-price
| capacity-optimized
spotAllocationStrategy
- Indicates how to allocate instances across Spot Instance pools.
If the allocation strategy is lowest-price
, the Auto Scaling group launches instances using
the Spot pools with the lowest price, and evenly allocates your instances across the number of Spot pools
that you specify. If the allocation strategy is capacity-optimized
, the Auto Scaling group
launches instances using Spot pools that are optimally chosen based on the available Spot capacity.
The default Spot allocation strategy for calls that you make through the API, the AWS CLI, or the AWS SDKs
is lowest-price
. The default Spot allocation strategy for the AWS Management Console is
capacity-optimized
.
Valid values: lowest-price
| capacity-optimized
public void setSpotInstancePools(Integer spotInstancePools)
The number of Spot Instance pools across which to allocate your Spot Instances. The Spot pools are determined from the different instance types in the Overrides array of LaunchTemplate. Default if not set is 2.
Used only when the Spot allocation strategy is lowest-price
.
Valid Range: Minimum value of 1. Maximum value of 20.
spotInstancePools
- The number of Spot Instance pools across which to allocate your Spot Instances. The Spot pools are
determined from the different instance types in the Overrides array of LaunchTemplate. Default if
not set is 2.
Used only when the Spot allocation strategy is lowest-price
.
Valid Range: Minimum value of 1. Maximum value of 20.
public Integer getSpotInstancePools()
The number of Spot Instance pools across which to allocate your Spot Instances. The Spot pools are determined from the different instance types in the Overrides array of LaunchTemplate. Default if not set is 2.
Used only when the Spot allocation strategy is lowest-price
.
Valid Range: Minimum value of 1. Maximum value of 20.
Used only when the Spot allocation strategy is lowest-price
.
Valid Range: Minimum value of 1. Maximum value of 20.
public InstancesDistribution withSpotInstancePools(Integer spotInstancePools)
The number of Spot Instance pools across which to allocate your Spot Instances. The Spot pools are determined from the different instance types in the Overrides array of LaunchTemplate. Default if not set is 2.
Used only when the Spot allocation strategy is lowest-price
.
Valid Range: Minimum value of 1. Maximum value of 20.
spotInstancePools
- The number of Spot Instance pools across which to allocate your Spot Instances. The Spot pools are
determined from the different instance types in the Overrides array of LaunchTemplate. Default if
not set is 2.
Used only when the Spot allocation strategy is lowest-price
.
Valid Range: Minimum value of 1. Maximum value of 20.
public void setSpotMaxPrice(String spotMaxPrice)
The maximum price per unit hour that you are willing to pay for a Spot Instance. If you leave the value of this parameter blank (which is the default), the maximum Spot price is set at the On-Demand price.
To remove a value that you previously set, include the parameter but leave the value blank.
spotMaxPrice
- The maximum price per unit hour that you are willing to pay for a Spot Instance. If you leave the value of
this parameter blank (which is the default), the maximum Spot price is set at the On-Demand price.
To remove a value that you previously set, include the parameter but leave the value blank.
public String getSpotMaxPrice()
The maximum price per unit hour that you are willing to pay for a Spot Instance. If you leave the value of this parameter blank (which is the default), the maximum Spot price is set at the On-Demand price.
To remove a value that you previously set, include the parameter but leave the value blank.
To remove a value that you previously set, include the parameter but leave the value blank.
public InstancesDistribution withSpotMaxPrice(String spotMaxPrice)
The maximum price per unit hour that you are willing to pay for a Spot Instance. If you leave the value of this parameter blank (which is the default), the maximum Spot price is set at the On-Demand price.
To remove a value that you previously set, include the parameter but leave the value blank.
spotMaxPrice
- The maximum price per unit hour that you are willing to pay for a Spot Instance. If you leave the value of
this parameter blank (which is the default), the maximum Spot price is set at the On-Demand price.
To remove a value that you previously set, include the parameter but leave the value blank.
public String toString()
toString
in class Object
Object.toString()
public InstancesDistribution clone()
Copyright © 2013 Amazon Web Services, Inc. All Rights Reserved.