Struct rusoto_autoscaling::InstancesDistribution
source · [−]pub struct InstancesDistribution {
pub on_demand_allocation_strategy: Option<String>,
pub on_demand_base_capacity: Option<i64>,
pub on_demand_percentage_above_base_capacity: Option<i64>,
pub spot_allocation_strategy: Option<String>,
pub spot_instance_pools: Option<i64>,
pub spot_max_price: Option<String>,
}
Expand description
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 capacities.
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.
Fields
on_demand_allocation_strategy: Option<String>
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 types in the LaunchTemplateOverrides
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.
on_demand_base_capacity: Option<i64>
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. Defaults to 0 if not specified. If you specify weights for the instance types in the overrides, set the value of OnDemandBaseCapacity
in terms of the number of capacity units, and not the number of instances.
on_demand_percentage_above_base_capacity: Option<i64>
Controls the percentages of On-Demand Instances and Spot Instances for your additional capacity beyond OnDemandBaseCapacity
. Expressed as a number (for example, 20 specifies 20% On-Demand Instances, 80% Spot Instances). Defaults to 100 if not specified. If set to 100, only On-Demand Instances are provisioned.
spot_allocation_strategy: Option<String>
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. Defaults to lowest-price
if not specified.
If the allocation strategy is capacity-optimized
(recommended), the Auto Scaling group launches instances using Spot pools that are optimally chosen based on the available Spot capacity. Alternatively, you can use capacity-optimized-prioritized
and set the order of instance types in the list of launch template overrides from highest to lowest priority (from first to last in the list). Amazon EC2 Auto Scaling honors the instance type priorities on a best-effort basis but optimizes for capacity first.
spot_instance_pools: Option<i64>
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. Valid only when the Spot allocation strategy is lowest-price
. Value must be in the range of 1 to 20. Defaults to 2 if not specified.
spot_max_price: Option<String>
The maximum price per unit hour that you are willing to pay for a Spot Instance. If you leave the value at its default (empty), Amazon EC2 Auto Scaling uses the On-Demand price as the maximum Spot price. To remove a value that you previously set, include the property but specify an empty string ("") for the value.
Trait Implementations
sourceimpl Clone for InstancesDistribution
impl Clone for InstancesDistribution
sourcefn clone(&self) -> InstancesDistribution
fn clone(&self) -> InstancesDistribution
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
sourceimpl Debug for InstancesDistribution
impl Debug for InstancesDistribution
sourceimpl Default for InstancesDistribution
impl Default for InstancesDistribution
sourcefn default() -> InstancesDistribution
fn default() -> InstancesDistribution
Returns the “default value” for a type. Read more
sourceimpl PartialEq<InstancesDistribution> for InstancesDistribution
impl PartialEq<InstancesDistribution> for InstancesDistribution
sourcefn eq(&self, other: &InstancesDistribution) -> bool
fn eq(&self, other: &InstancesDistribution) -> bool
This method tests for self
and other
values to be equal, and is used
by ==
. Read more
sourcefn ne(&self, other: &InstancesDistribution) -> bool
fn ne(&self, other: &InstancesDistribution) -> bool
This method tests for !=
.
impl StructuralPartialEq for InstancesDistribution
Auto Trait Implementations
impl RefUnwindSafe for InstancesDistribution
impl Send for InstancesDistribution
impl Sync for InstancesDistribution
impl Unpin for InstancesDistribution
impl UnwindSafe for InstancesDistribution
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
sourcefn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more
sourceimpl<T> WithSubscriber for T
impl<T> WithSubscriber for T
sourcefn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
Attaches the provided Subscriber
to this type, returning a
WithDispatch
wrapper. Read more
sourcefn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Attaches the current default Subscriber
to this type, returning a
WithDispatch
wrapper. Read more