Struct aws_sdk_ecs::model::CapacityProviderStrategyItem
source · [−]#[non_exhaustive]pub struct CapacityProviderStrategyItem {
pub capacity_provider: Option<String>,
pub weight: i32,
pub base: i32,
}
Expand description
The details of a capacity provider strategy. A capacity provider strategy can be set when using the RunTask
or CreateCluster
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 a Fargate capacity provider, specify either the FARGATE
or FARGATE_SPOT
capacity 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.
A capacity provider strategy may contain a maximum of 6 capacity providers.
Fields (Non-exhaustive)
This struct is marked as non-exhaustive
Struct { .. }
syntax; cannot be matched against without a wildcard ..
; and struct update syntax will not work.capacity_provider: Option<String>
The short name of the capacity provider.
weight: i32
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 the base
value, if defined, is satisfied.
If no weight
value is specified, the default value of 0
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 of 0
can't be used to place tasks. If you specify multiple capacity providers in a strategy that all have a weight of 0
, any RunTask
or CreateService
actions using the capacity provider strategy will fail.
An example scenario for using weights is defining a strategy that contains two capacity providers and both have a weight of 1
, then when the base
is satisfied, the tasks will be split evenly across the two capacity providers. Using that same logic, if you specify a weight of 1
for capacityProviderA and a weight of 4
for capacityProviderB, then for every one task that's run using capacityProviderA, four tasks would use capacityProviderB.
base: i32
The base value designates how many tasks, at a minimum, to run on the specified capacity provider. 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.
Implementations
sourceimpl CapacityProviderStrategyItem
impl CapacityProviderStrategyItem
sourcepub fn capacity_provider(&self) -> Option<&str>
pub fn capacity_provider(&self) -> Option<&str>
The short name of the capacity provider.
sourcepub fn weight(&self) -> i32
pub fn weight(&self) -> i32
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 the base
value, if defined, is satisfied.
If no weight
value is specified, the default value of 0
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 of 0
can't be used to place tasks. If you specify multiple capacity providers in a strategy that all have a weight of 0
, any RunTask
or CreateService
actions using the capacity provider strategy will fail.
An example scenario for using weights is defining a strategy that contains two capacity providers and both have a weight of 1
, then when the base
is satisfied, the tasks will be split evenly across the two capacity providers. Using that same logic, if you specify a weight of 1
for capacityProviderA and a weight of 4
for capacityProviderB, then for every one task that's run using capacityProviderA, four tasks would use capacityProviderB.
sourceimpl CapacityProviderStrategyItem
impl CapacityProviderStrategyItem
sourcepub fn builder() -> Builder
pub fn builder() -> Builder
Creates a new builder-style object to manufacture CapacityProviderStrategyItem
Trait Implementations
sourceimpl Clone for CapacityProviderStrategyItem
impl Clone for CapacityProviderStrategyItem
sourcefn clone(&self) -> CapacityProviderStrategyItem
fn clone(&self) -> CapacityProviderStrategyItem
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 CapacityProviderStrategyItem
impl Debug for CapacityProviderStrategyItem
sourceimpl PartialEq<CapacityProviderStrategyItem> for CapacityProviderStrategyItem
impl PartialEq<CapacityProviderStrategyItem> for CapacityProviderStrategyItem
sourcefn eq(&self, other: &CapacityProviderStrategyItem) -> bool
fn eq(&self, other: &CapacityProviderStrategyItem) -> bool
This method tests for self
and other
values to be equal, and is used
by ==
. Read more
sourcefn ne(&self, other: &CapacityProviderStrategyItem) -> bool
fn ne(&self, other: &CapacityProviderStrategyItem) -> bool
This method tests for !=
.
impl StructuralPartialEq for CapacityProviderStrategyItem
Auto Trait Implementations
impl RefUnwindSafe for CapacityProviderStrategyItem
impl Send for CapacityProviderStrategyItem
impl Sync for CapacityProviderStrategyItem
impl Unpin for CapacityProviderStrategyItem
impl UnwindSafe for CapacityProviderStrategyItem
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> 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