[][src]Trait rusoto_application_autoscaling::ApplicationAutoScaling

pub trait ApplicationAutoScaling {
#[must_use]    pub fn delete_scaling_policy<'life0, 'async_trait>(
        &'life0 self,
        input: DeleteScalingPolicyRequest
    ) -> Pin<Box<dyn Future<Output = Result<DeleteScalingPolicyResponse, RusotoError<DeleteScalingPolicyError>>> + Send + 'async_trait>>
    where
        'life0: 'async_trait,
        Self: 'async_trait
;
#[must_use] pub fn delete_scheduled_action<'life0, 'async_trait>(
        &'life0 self,
        input: DeleteScheduledActionRequest
    ) -> Pin<Box<dyn Future<Output = Result<DeleteScheduledActionResponse, RusotoError<DeleteScheduledActionError>>> + Send + 'async_trait>>
    where
        'life0: 'async_trait,
        Self: 'async_trait
;
#[must_use] pub fn deregister_scalable_target<'life0, 'async_trait>(
        &'life0 self,
        input: DeregisterScalableTargetRequest
    ) -> Pin<Box<dyn Future<Output = Result<DeregisterScalableTargetResponse, RusotoError<DeregisterScalableTargetError>>> + Send + 'async_trait>>
    where
        'life0: 'async_trait,
        Self: 'async_trait
;
#[must_use] pub fn describe_scalable_targets<'life0, 'async_trait>(
        &'life0 self,
        input: DescribeScalableTargetsRequest
    ) -> Pin<Box<dyn Future<Output = Result<DescribeScalableTargetsResponse, RusotoError<DescribeScalableTargetsError>>> + Send + 'async_trait>>
    where
        'life0: 'async_trait,
        Self: 'async_trait
;
#[must_use] pub fn describe_scaling_activities<'life0, 'async_trait>(
        &'life0 self,
        input: DescribeScalingActivitiesRequest
    ) -> Pin<Box<dyn Future<Output = Result<DescribeScalingActivitiesResponse, RusotoError<DescribeScalingActivitiesError>>> + Send + 'async_trait>>
    where
        'life0: 'async_trait,
        Self: 'async_trait
;
#[must_use] pub fn describe_scaling_policies<'life0, 'async_trait>(
        &'life0 self,
        input: DescribeScalingPoliciesRequest
    ) -> Pin<Box<dyn Future<Output = Result<DescribeScalingPoliciesResponse, RusotoError<DescribeScalingPoliciesError>>> + Send + 'async_trait>>
    where
        'life0: 'async_trait,
        Self: 'async_trait
;
#[must_use] pub fn describe_scheduled_actions<'life0, 'async_trait>(
        &'life0 self,
        input: DescribeScheduledActionsRequest
    ) -> Pin<Box<dyn Future<Output = Result<DescribeScheduledActionsResponse, RusotoError<DescribeScheduledActionsError>>> + Send + 'async_trait>>
    where
        'life0: 'async_trait,
        Self: 'async_trait
;
#[must_use] pub fn put_scaling_policy<'life0, 'async_trait>(
        &'life0 self,
        input: PutScalingPolicyRequest
    ) -> Pin<Box<dyn Future<Output = Result<PutScalingPolicyResponse, RusotoError<PutScalingPolicyError>>> + Send + 'async_trait>>
    where
        'life0: 'async_trait,
        Self: 'async_trait
;
#[must_use] pub fn put_scheduled_action<'life0, 'async_trait>(
        &'life0 self,
        input: PutScheduledActionRequest
    ) -> Pin<Box<dyn Future<Output = Result<PutScheduledActionResponse, RusotoError<PutScheduledActionError>>> + Send + 'async_trait>>
    where
        'life0: 'async_trait,
        Self: 'async_trait
;
#[must_use] pub fn register_scalable_target<'life0, 'async_trait>(
        &'life0 self,
        input: RegisterScalableTargetRequest
    ) -> Pin<Box<dyn Future<Output = Result<RegisterScalableTargetResponse, RusotoError<RegisterScalableTargetError>>> + Send + 'async_trait>>
    where
        'life0: 'async_trait,
        Self: 'async_trait
; }

Trait representing the capabilities of the Application Auto Scaling API. Application Auto Scaling clients implement this trait.

Required methods

#[must_use]pub fn delete_scaling_policy<'life0, 'async_trait>(
    &'life0 self,
    input: DeleteScalingPolicyRequest
) -> Pin<Box<dyn Future<Output = Result<DeleteScalingPolicyResponse, RusotoError<DeleteScalingPolicyError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Deletes the specified scaling policy for an Application Auto Scaling scalable target.

Deleting a step scaling policy deletes the underlying alarm action, but does not delete the CloudWatch alarm associated with the scaling policy, even if it no longer has an associated action.

For more information, see Delete a Step Scaling Policy and Delete a Target Tracking Scaling Policy in the Application Auto Scaling User Guide.

#[must_use]pub fn delete_scheduled_action<'life0, 'async_trait>(
    &'life0 self,
    input: DeleteScheduledActionRequest
) -> Pin<Box<dyn Future<Output = Result<DeleteScheduledActionResponse, RusotoError<DeleteScheduledActionError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Deletes the specified scheduled action for an Application Auto Scaling scalable target.

For more information, see Delete a Scheduled Action in the Application Auto Scaling User Guide.

#[must_use]pub fn deregister_scalable_target<'life0, 'async_trait>(
    &'life0 self,
    input: DeregisterScalableTargetRequest
) -> Pin<Box<dyn Future<Output = Result<DeregisterScalableTargetResponse, RusotoError<DeregisterScalableTargetError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Deregisters an Application Auto Scaling scalable target when you have finished using it. To see which resources have been registered, use DescribeScalableTargets.

Deregistering a scalable target deletes the scaling policies and the scheduled actions that are associated with it.

#[must_use]pub fn describe_scalable_targets<'life0, 'async_trait>(
    &'life0 self,
    input: DescribeScalableTargetsRequest
) -> Pin<Box<dyn Future<Output = Result<DescribeScalableTargetsResponse, RusotoError<DescribeScalableTargetsError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Gets information about the scalable targets in the specified namespace.

You can filter the results using ResourceIds and ScalableDimension.

#[must_use]pub fn describe_scaling_activities<'life0, 'async_trait>(
    &'life0 self,
    input: DescribeScalingActivitiesRequest
) -> Pin<Box<dyn Future<Output = Result<DescribeScalingActivitiesResponse, RusotoError<DescribeScalingActivitiesError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Provides descriptive information about the scaling activities in the specified namespace from the previous six weeks.

You can filter the results using ResourceId and ScalableDimension.

#[must_use]pub fn describe_scaling_policies<'life0, 'async_trait>(
    &'life0 self,
    input: DescribeScalingPoliciesRequest
) -> Pin<Box<dyn Future<Output = Result<DescribeScalingPoliciesResponse, RusotoError<DescribeScalingPoliciesError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Describes the Application Auto Scaling scaling policies for the specified service namespace.

You can filter the results using ResourceId, ScalableDimension, and PolicyNames.

For more information, see Target Tracking Scaling Policies and Step Scaling Policies in the Application Auto Scaling User Guide.

#[must_use]pub fn describe_scheduled_actions<'life0, 'async_trait>(
    &'life0 self,
    input: DescribeScheduledActionsRequest
) -> Pin<Box<dyn Future<Output = Result<DescribeScheduledActionsResponse, RusotoError<DescribeScheduledActionsError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Describes the Application Auto Scaling scheduled actions for the specified service namespace.

You can filter the results using the ResourceId, ScalableDimension, and ScheduledActionNames parameters.

For more information, see Scheduled Scaling in the Application Auto Scaling User Guide.

#[must_use]pub fn put_scaling_policy<'life0, 'async_trait>(
    &'life0 self,
    input: PutScalingPolicyRequest
) -> Pin<Box<dyn Future<Output = Result<PutScalingPolicyResponse, RusotoError<PutScalingPolicyError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Creates or updates a scaling policy for an Application Auto Scaling scalable target.

Each scalable target is identified by a service namespace, resource ID, and scalable dimension. A scaling policy applies to the scalable target identified by those three attributes. You cannot create a scaling policy until you have registered the resource as a scalable target.

Multiple scaling policies can be in force at the same time for the same scalable target. You can have one or more target tracking scaling policies, one or more step scaling policies, or both. However, there is a chance that multiple policies could conflict, instructing the scalable target to scale out or in at the same time. Application Auto Scaling gives precedence to the policy that provides the largest capacity for both scale out and scale in. For example, if one policy increases capacity by 3, another policy increases capacity by 200 percent, and the current capacity is 10, Application Auto Scaling uses the policy with the highest calculated capacity (200% of 10 = 20) and scales out to 30.

We recommend caution, however, when using target tracking scaling policies with step scaling policies because conflicts between these policies can cause undesirable behavior. For example, if the step scaling policy initiates a scale-in activity before the target tracking policy is ready to scale in, the scale-in activity will not be blocked. After the scale-in activity completes, the target tracking policy could instruct the scalable target to scale out again.

For more information, see Target Tracking Scaling Policies and Step Scaling Policies in the Application Auto Scaling User Guide.

If a scalable target is deregistered, the scalable target is no longer available to execute scaling policies. Any scaling policies that were specified for the scalable target are deleted.

#[must_use]pub fn put_scheduled_action<'life0, 'async_trait>(
    &'life0 self,
    input: PutScheduledActionRequest
) -> Pin<Box<dyn Future<Output = Result<PutScheduledActionResponse, RusotoError<PutScheduledActionError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Creates or updates a scheduled action for an Application Auto Scaling scalable target.

Each scalable target is identified by a service namespace, resource ID, and scalable dimension. A scheduled action applies to the scalable target identified by those three attributes. You cannot create a scheduled action until you have registered the resource as a scalable target.

When start and end times are specified with a recurring schedule using a cron expression or rates, they form the boundaries of when the recurring action starts and stops.

To update a scheduled action, specify the parameters that you want to change. If you don't specify start and end times, the old values are deleted.

For more information, see Scheduled Scaling in the Application Auto Scaling User Guide.

If a scalable target is deregistered, the scalable target is no longer available to run scheduled actions. Any scheduled actions that were specified for the scalable target are deleted.

#[must_use]pub fn register_scalable_target<'life0, 'async_trait>(
    &'life0 self,
    input: RegisterScalableTargetRequest
) -> Pin<Box<dyn Future<Output = Result<RegisterScalableTargetResponse, RusotoError<RegisterScalableTargetError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Registers or updates a scalable target.

A scalable target is a resource that Application Auto Scaling can scale out and scale in. Scalable targets are uniquely identified by the combination of resource ID, scalable dimension, and namespace.

When you register a new scalable target, you must specify values for minimum and maximum capacity. Application Auto Scaling scaling policies will not scale capacity to values that are outside of this range.

After you register a scalable target, you do not need to register it again to use other Application Auto Scaling operations. To see which resources have been registered, use DescribeScalableTargets. You can also view the scaling policies for a service namespace by using DescribeScalableTargets. If you no longer need a scalable target, you can deregister it by using DeregisterScalableTarget.

To update a scalable target, specify the parameters that you want to change. Include the parameters that identify the scalable target: resource ID, scalable dimension, and namespace. Any parameters that you don't specify are not changed by this update request.

Loading content...

Implementors

impl ApplicationAutoScaling for ApplicationAutoScalingClient[src]

pub fn delete_scaling_policy<'life0, 'async_trait>(
    &'life0 self,
    input: DeleteScalingPolicyRequest
) -> Pin<Box<dyn Future<Output = Result<DeleteScalingPolicyResponse, RusotoError<DeleteScalingPolicyError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Deletes the specified scaling policy for an Application Auto Scaling scalable target.

Deleting a step scaling policy deletes the underlying alarm action, but does not delete the CloudWatch alarm associated with the scaling policy, even if it no longer has an associated action.

For more information, see Delete a Step Scaling Policy and Delete a Target Tracking Scaling Policy in the Application Auto Scaling User Guide.

pub fn delete_scheduled_action<'life0, 'async_trait>(
    &'life0 self,
    input: DeleteScheduledActionRequest
) -> Pin<Box<dyn Future<Output = Result<DeleteScheduledActionResponse, RusotoError<DeleteScheduledActionError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Deletes the specified scheduled action for an Application Auto Scaling scalable target.

For more information, see Delete a Scheduled Action in the Application Auto Scaling User Guide.

pub fn deregister_scalable_target<'life0, 'async_trait>(
    &'life0 self,
    input: DeregisterScalableTargetRequest
) -> Pin<Box<dyn Future<Output = Result<DeregisterScalableTargetResponse, RusotoError<DeregisterScalableTargetError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Deregisters an Application Auto Scaling scalable target when you have finished using it. To see which resources have been registered, use DescribeScalableTargets.

Deregistering a scalable target deletes the scaling policies and the scheduled actions that are associated with it.

pub fn describe_scalable_targets<'life0, 'async_trait>(
    &'life0 self,
    input: DescribeScalableTargetsRequest
) -> Pin<Box<dyn Future<Output = Result<DescribeScalableTargetsResponse, RusotoError<DescribeScalableTargetsError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Gets information about the scalable targets in the specified namespace.

You can filter the results using ResourceIds and ScalableDimension.

pub fn describe_scaling_activities<'life0, 'async_trait>(
    &'life0 self,
    input: DescribeScalingActivitiesRequest
) -> Pin<Box<dyn Future<Output = Result<DescribeScalingActivitiesResponse, RusotoError<DescribeScalingActivitiesError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Provides descriptive information about the scaling activities in the specified namespace from the previous six weeks.

You can filter the results using ResourceId and ScalableDimension.

pub fn describe_scaling_policies<'life0, 'async_trait>(
    &'life0 self,
    input: DescribeScalingPoliciesRequest
) -> Pin<Box<dyn Future<Output = Result<DescribeScalingPoliciesResponse, RusotoError<DescribeScalingPoliciesError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Describes the Application Auto Scaling scaling policies for the specified service namespace.

You can filter the results using ResourceId, ScalableDimension, and PolicyNames.

For more information, see Target Tracking Scaling Policies and Step Scaling Policies in the Application Auto Scaling User Guide.

pub fn describe_scheduled_actions<'life0, 'async_trait>(
    &'life0 self,
    input: DescribeScheduledActionsRequest
) -> Pin<Box<dyn Future<Output = Result<DescribeScheduledActionsResponse, RusotoError<DescribeScheduledActionsError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Describes the Application Auto Scaling scheduled actions for the specified service namespace.

You can filter the results using the ResourceId, ScalableDimension, and ScheduledActionNames parameters.

For more information, see Scheduled Scaling in the Application Auto Scaling User Guide.

pub fn put_scaling_policy<'life0, 'async_trait>(
    &'life0 self,
    input: PutScalingPolicyRequest
) -> Pin<Box<dyn Future<Output = Result<PutScalingPolicyResponse, RusotoError<PutScalingPolicyError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Creates or updates a scaling policy for an Application Auto Scaling scalable target.

Each scalable target is identified by a service namespace, resource ID, and scalable dimension. A scaling policy applies to the scalable target identified by those three attributes. You cannot create a scaling policy until you have registered the resource as a scalable target.

Multiple scaling policies can be in force at the same time for the same scalable target. You can have one or more target tracking scaling policies, one or more step scaling policies, or both. However, there is a chance that multiple policies could conflict, instructing the scalable target to scale out or in at the same time. Application Auto Scaling gives precedence to the policy that provides the largest capacity for both scale out and scale in. For example, if one policy increases capacity by 3, another policy increases capacity by 200 percent, and the current capacity is 10, Application Auto Scaling uses the policy with the highest calculated capacity (200% of 10 = 20) and scales out to 30.

We recommend caution, however, when using target tracking scaling policies with step scaling policies because conflicts between these policies can cause undesirable behavior. For example, if the step scaling policy initiates a scale-in activity before the target tracking policy is ready to scale in, the scale-in activity will not be blocked. After the scale-in activity completes, the target tracking policy could instruct the scalable target to scale out again.

For more information, see Target Tracking Scaling Policies and Step Scaling Policies in the Application Auto Scaling User Guide.

If a scalable target is deregistered, the scalable target is no longer available to execute scaling policies. Any scaling policies that were specified for the scalable target are deleted.

pub fn put_scheduled_action<'life0, 'async_trait>(
    &'life0 self,
    input: PutScheduledActionRequest
) -> Pin<Box<dyn Future<Output = Result<PutScheduledActionResponse, RusotoError<PutScheduledActionError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Creates or updates a scheduled action for an Application Auto Scaling scalable target.

Each scalable target is identified by a service namespace, resource ID, and scalable dimension. A scheduled action applies to the scalable target identified by those three attributes. You cannot create a scheduled action until you have registered the resource as a scalable target.

When start and end times are specified with a recurring schedule using a cron expression or rates, they form the boundaries of when the recurring action starts and stops.

To update a scheduled action, specify the parameters that you want to change. If you don't specify start and end times, the old values are deleted.

For more information, see Scheduled Scaling in the Application Auto Scaling User Guide.

If a scalable target is deregistered, the scalable target is no longer available to run scheduled actions. Any scheduled actions that were specified for the scalable target are deleted.

pub fn register_scalable_target<'life0, 'async_trait>(
    &'life0 self,
    input: RegisterScalableTargetRequest
) -> Pin<Box<dyn Future<Output = Result<RegisterScalableTargetResponse, RusotoError<RegisterScalableTargetError>>> + Send + 'async_trait>> where
    'life0: 'async_trait,
    Self: 'async_trait, 
[src]

Registers or updates a scalable target.

A scalable target is a resource that Application Auto Scaling can scale out and scale in. Scalable targets are uniquely identified by the combination of resource ID, scalable dimension, and namespace.

When you register a new scalable target, you must specify values for minimum and maximum capacity. Application Auto Scaling scaling policies will not scale capacity to values that are outside of this range.

After you register a scalable target, you do not need to register it again to use other Application Auto Scaling operations. To see which resources have been registered, use DescribeScalableTargets. You can also view the scaling policies for a service namespace by using DescribeScalableTargets. If you no longer need a scalable target, you can deregister it by using DeregisterScalableTarget.

To update a scalable target, specify the parameters that you want to change. Include the parameters that identify the scalable target: resource ID, scalable dimension, and namespace. Any parameters that you don't specify are not changed by this update request.

Loading content...