All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.amazonaws.services.autoscalingplans.model.TargetTrackingConfiguration Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS Auto Scaling Plans module holds the client classes that are used for communicating with AWS Auto Scaling Plans Service

There is a newer version: 1.12.780
Show newest version
/*
 * Copyright 2019-2024 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
 * CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
 * and limitations under the License.
 */
package com.amazonaws.services.autoscalingplans.model;

import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;

/**
 * 

* Describes a target tracking configuration to use with AWS Auto Scaling. Used with ScalingInstruction and * ScalingPolicy. *

* * @see AWS API Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class TargetTrackingConfiguration implements Serializable, Cloneable, StructuredPojo { /** *

* A predefined metric. You can specify either a predefined metric or a customized metric. *

*/ private PredefinedScalingMetricSpecification predefinedScalingMetricSpecification; /** *

* A customized metric. You can specify either a predefined metric or a customized metric. *

*/ private CustomizedScalingMetricSpecification customizedScalingMetricSpecification; /** *

* The target value for the metric. Although this property accepts numbers of type Double, it won't accept values * that are either too small or too large. Values must be in the range of -2^360 to 2^360. *

*/ private Double targetValue; /** *

* Indicates whether scale in by the target tracking scaling policy is disabled. If the value is true, * scale in is disabled and the target tracking scaling policy doesn't remove capacity from the scalable resource. * Otherwise, scale in is enabled and the target tracking scaling policy can remove capacity from the scalable * resource. *

*

* The default value is false. *

*/ private Boolean disableScaleIn; /** *

* The amount of time, in seconds, to wait for a previous scale-out activity to take effect. This property is not * used if the scalable resource is an Auto Scaling group. *

*

* With the scale-out cooldown period, the intention is to continuously (but not excessively) scale out. * After Auto Scaling successfully scales out using a target tracking scaling policy, it starts to calculate the * cooldown time. The scaling policy won't increase the desired capacity again unless either a larger scale out is * triggered or the cooldown period ends. *

*/ private Integer scaleOutCooldown; /** *

* The amount of time, in seconds, after a scale-in activity completes before another scale-in activity can start. * This property is not used if the scalable resource is an Auto Scaling group. *

*

* With the scale-in cooldown period, the intention is to scale in conservatively to protect your * application’s availability, so scale-in activities are blocked until the cooldown period has expired. However, if * another alarm triggers a scale-out activity during the scale-in cooldown period, Auto Scaling scales out the * target immediately. In this case, the scale-in cooldown period stops and doesn't complete. *

*/ private Integer scaleInCooldown; /** *

* The estimated time, in seconds, until a newly launched instance can contribute to the CloudWatch metrics. This * value is used only if the resource is an Auto Scaling group. *

*/ private Integer estimatedInstanceWarmup; /** *

* A predefined metric. You can specify either a predefined metric or a customized metric. *

* * @param predefinedScalingMetricSpecification * A predefined metric. You can specify either a predefined metric or a customized metric. */ public void setPredefinedScalingMetricSpecification(PredefinedScalingMetricSpecification predefinedScalingMetricSpecification) { this.predefinedScalingMetricSpecification = predefinedScalingMetricSpecification; } /** *

* A predefined metric. You can specify either a predefined metric or a customized metric. *

* * @return A predefined metric. You can specify either a predefined metric or a customized metric. */ public PredefinedScalingMetricSpecification getPredefinedScalingMetricSpecification() { return this.predefinedScalingMetricSpecification; } /** *

* A predefined metric. You can specify either a predefined metric or a customized metric. *

* * @param predefinedScalingMetricSpecification * A predefined metric. You can specify either a predefined metric or a customized metric. * @return Returns a reference to this object so that method calls can be chained together. */ public TargetTrackingConfiguration withPredefinedScalingMetricSpecification(PredefinedScalingMetricSpecification predefinedScalingMetricSpecification) { setPredefinedScalingMetricSpecification(predefinedScalingMetricSpecification); return this; } /** *

* A customized metric. You can specify either a predefined metric or a customized metric. *

* * @param customizedScalingMetricSpecification * A customized metric. You can specify either a predefined metric or a customized metric. */ public void setCustomizedScalingMetricSpecification(CustomizedScalingMetricSpecification customizedScalingMetricSpecification) { this.customizedScalingMetricSpecification = customizedScalingMetricSpecification; } /** *

* A customized metric. You can specify either a predefined metric or a customized metric. *

* * @return A customized metric. You can specify either a predefined metric or a customized metric. */ public CustomizedScalingMetricSpecification getCustomizedScalingMetricSpecification() { return this.customizedScalingMetricSpecification; } /** *

* A customized metric. You can specify either a predefined metric or a customized metric. *

* * @param customizedScalingMetricSpecification * A customized metric. You can specify either a predefined metric or a customized metric. * @return Returns a reference to this object so that method calls can be chained together. */ public TargetTrackingConfiguration withCustomizedScalingMetricSpecification(CustomizedScalingMetricSpecification customizedScalingMetricSpecification) { setCustomizedScalingMetricSpecification(customizedScalingMetricSpecification); return this; } /** *

* The target value for the metric. Although this property accepts numbers of type Double, it won't accept values * that are either too small or too large. Values must be in the range of -2^360 to 2^360. *

* * @param targetValue * The target value for the metric. Although this property accepts numbers of type Double, it won't accept * values that are either too small or too large. Values must be in the range of -2^360 to 2^360. */ public void setTargetValue(Double targetValue) { this.targetValue = targetValue; } /** *

* The target value for the metric. Although this property accepts numbers of type Double, it won't accept values * that are either too small or too large. Values must be in the range of -2^360 to 2^360. *

* * @return The target value for the metric. Although this property accepts numbers of type Double, it won't accept * values that are either too small or too large. Values must be in the range of -2^360 to 2^360. */ public Double getTargetValue() { return this.targetValue; } /** *

* The target value for the metric. Although this property accepts numbers of type Double, it won't accept values * that are either too small or too large. Values must be in the range of -2^360 to 2^360. *

* * @param targetValue * The target value for the metric. Although this property accepts numbers of type Double, it won't accept * values that are either too small or too large. Values must be in the range of -2^360 to 2^360. * @return Returns a reference to this object so that method calls can be chained together. */ public TargetTrackingConfiguration withTargetValue(Double targetValue) { setTargetValue(targetValue); return this; } /** *

* Indicates whether scale in by the target tracking scaling policy is disabled. If the value is true, * scale in is disabled and the target tracking scaling policy doesn't remove capacity from the scalable resource. * Otherwise, scale in is enabled and the target tracking scaling policy can remove capacity from the scalable * resource. *

*

* The default value is false. *

* * @param disableScaleIn * Indicates whether scale in by the target tracking scaling policy is disabled. If the value is * true, scale in is disabled and the target tracking scaling policy doesn't remove capacity * from the scalable resource. Otherwise, scale in is enabled and the target tracking scaling policy can * remove capacity from the scalable resource.

*

* The default value is false. */ public void setDisableScaleIn(Boolean disableScaleIn) { this.disableScaleIn = disableScaleIn; } /** *

* Indicates whether scale in by the target tracking scaling policy is disabled. If the value is true, * scale in is disabled and the target tracking scaling policy doesn't remove capacity from the scalable resource. * Otherwise, scale in is enabled and the target tracking scaling policy can remove capacity from the scalable * resource. *

*

* The default value is false. *

* * @return Indicates whether scale in by the target tracking scaling policy is disabled. If the value is * true, scale in is disabled and the target tracking scaling policy doesn't remove capacity * from the scalable resource. Otherwise, scale in is enabled and the target tracking scaling policy can * remove capacity from the scalable resource.

*

* The default value is false. */ public Boolean getDisableScaleIn() { return this.disableScaleIn; } /** *

* Indicates whether scale in by the target tracking scaling policy is disabled. If the value is true, * scale in is disabled and the target tracking scaling policy doesn't remove capacity from the scalable resource. * Otherwise, scale in is enabled and the target tracking scaling policy can remove capacity from the scalable * resource. *

*

* The default value is false. *

* * @param disableScaleIn * Indicates whether scale in by the target tracking scaling policy is disabled. If the value is * true, scale in is disabled and the target tracking scaling policy doesn't remove capacity * from the scalable resource. Otherwise, scale in is enabled and the target tracking scaling policy can * remove capacity from the scalable resource.

*

* The default value is false. * @return Returns a reference to this object so that method calls can be chained together. */ public TargetTrackingConfiguration withDisableScaleIn(Boolean disableScaleIn) { setDisableScaleIn(disableScaleIn); return this; } /** *

* Indicates whether scale in by the target tracking scaling policy is disabled. If the value is true, * scale in is disabled and the target tracking scaling policy doesn't remove capacity from the scalable resource. * Otherwise, scale in is enabled and the target tracking scaling policy can remove capacity from the scalable * resource. *

*

* The default value is false. *

* * @return Indicates whether scale in by the target tracking scaling policy is disabled. If the value is * true, scale in is disabled and the target tracking scaling policy doesn't remove capacity * from the scalable resource. Otherwise, scale in is enabled and the target tracking scaling policy can * remove capacity from the scalable resource.

*

* The default value is false. */ public Boolean isDisableScaleIn() { return this.disableScaleIn; } /** *

* The amount of time, in seconds, to wait for a previous scale-out activity to take effect. This property is not * used if the scalable resource is an Auto Scaling group. *

*

* With the scale-out cooldown period, the intention is to continuously (but not excessively) scale out. * After Auto Scaling successfully scales out using a target tracking scaling policy, it starts to calculate the * cooldown time. The scaling policy won't increase the desired capacity again unless either a larger scale out is * triggered or the cooldown period ends. *

* * @param scaleOutCooldown * The amount of time, in seconds, to wait for a previous scale-out activity to take effect. This property is * not used if the scalable resource is an Auto Scaling group.

*

* With the scale-out cooldown period, the intention is to continuously (but not excessively) scale * out. After Auto Scaling successfully scales out using a target tracking scaling policy, it starts to * calculate the cooldown time. The scaling policy won't increase the desired capacity again unless either a * larger scale out is triggered or the cooldown period ends. */ public void setScaleOutCooldown(Integer scaleOutCooldown) { this.scaleOutCooldown = scaleOutCooldown; } /** *

* The amount of time, in seconds, to wait for a previous scale-out activity to take effect. This property is not * used if the scalable resource is an Auto Scaling group. *

*

* With the scale-out cooldown period, the intention is to continuously (but not excessively) scale out. * After Auto Scaling successfully scales out using a target tracking scaling policy, it starts to calculate the * cooldown time. The scaling policy won't increase the desired capacity again unless either a larger scale out is * triggered or the cooldown period ends. *

* * @return The amount of time, in seconds, to wait for a previous scale-out activity to take effect. This property * is not used if the scalable resource is an Auto Scaling group.

*

* With the scale-out cooldown period, the intention is to continuously (but not excessively) scale * out. After Auto Scaling successfully scales out using a target tracking scaling policy, it starts to * calculate the cooldown time. The scaling policy won't increase the desired capacity again unless either a * larger scale out is triggered or the cooldown period ends. */ public Integer getScaleOutCooldown() { return this.scaleOutCooldown; } /** *

* The amount of time, in seconds, to wait for a previous scale-out activity to take effect. This property is not * used if the scalable resource is an Auto Scaling group. *

*

* With the scale-out cooldown period, the intention is to continuously (but not excessively) scale out. * After Auto Scaling successfully scales out using a target tracking scaling policy, it starts to calculate the * cooldown time. The scaling policy won't increase the desired capacity again unless either a larger scale out is * triggered or the cooldown period ends. *

* * @param scaleOutCooldown * The amount of time, in seconds, to wait for a previous scale-out activity to take effect. This property is * not used if the scalable resource is an Auto Scaling group.

*

* With the scale-out cooldown period, the intention is to continuously (but not excessively) scale * out. After Auto Scaling successfully scales out using a target tracking scaling policy, it starts to * calculate the cooldown time. The scaling policy won't increase the desired capacity again unless either a * larger scale out is triggered or the cooldown period ends. * @return Returns a reference to this object so that method calls can be chained together. */ public TargetTrackingConfiguration withScaleOutCooldown(Integer scaleOutCooldown) { setScaleOutCooldown(scaleOutCooldown); return this; } /** *

* The amount of time, in seconds, after a scale-in activity completes before another scale-in activity can start. * This property is not used if the scalable resource is an Auto Scaling group. *

*

* With the scale-in cooldown period, the intention is to scale in conservatively to protect your * application’s availability, so scale-in activities are blocked until the cooldown period has expired. However, if * another alarm triggers a scale-out activity during the scale-in cooldown period, Auto Scaling scales out the * target immediately. In this case, the scale-in cooldown period stops and doesn't complete. *

* * @param scaleInCooldown * The amount of time, in seconds, after a scale-in activity completes before another scale-in activity can * start. This property is not used if the scalable resource is an Auto Scaling group.

*

* With the scale-in cooldown period, the intention is to scale in conservatively to protect your * application’s availability, so scale-in activities are blocked until the cooldown period has expired. * However, if another alarm triggers a scale-out activity during the scale-in cooldown period, Auto Scaling * scales out the target immediately. In this case, the scale-in cooldown period stops and doesn't complete. */ public void setScaleInCooldown(Integer scaleInCooldown) { this.scaleInCooldown = scaleInCooldown; } /** *

* The amount of time, in seconds, after a scale-in activity completes before another scale-in activity can start. * This property is not used if the scalable resource is an Auto Scaling group. *

*

* With the scale-in cooldown period, the intention is to scale in conservatively to protect your * application’s availability, so scale-in activities are blocked until the cooldown period has expired. However, if * another alarm triggers a scale-out activity during the scale-in cooldown period, Auto Scaling scales out the * target immediately. In this case, the scale-in cooldown period stops and doesn't complete. *

* * @return The amount of time, in seconds, after a scale-in activity completes before another scale-in activity can * start. This property is not used if the scalable resource is an Auto Scaling group.

*

* With the scale-in cooldown period, the intention is to scale in conservatively to protect your * application’s availability, so scale-in activities are blocked until the cooldown period has expired. * However, if another alarm triggers a scale-out activity during the scale-in cooldown period, Auto Scaling * scales out the target immediately. In this case, the scale-in cooldown period stops and doesn't complete. */ public Integer getScaleInCooldown() { return this.scaleInCooldown; } /** *

* The amount of time, in seconds, after a scale-in activity completes before another scale-in activity can start. * This property is not used if the scalable resource is an Auto Scaling group. *

*

* With the scale-in cooldown period, the intention is to scale in conservatively to protect your * application’s availability, so scale-in activities are blocked until the cooldown period has expired. However, if * another alarm triggers a scale-out activity during the scale-in cooldown period, Auto Scaling scales out the * target immediately. In this case, the scale-in cooldown period stops and doesn't complete. *

* * @param scaleInCooldown * The amount of time, in seconds, after a scale-in activity completes before another scale-in activity can * start. This property is not used if the scalable resource is an Auto Scaling group.

*

* With the scale-in cooldown period, the intention is to scale in conservatively to protect your * application’s availability, so scale-in activities are blocked until the cooldown period has expired. * However, if another alarm triggers a scale-out activity during the scale-in cooldown period, Auto Scaling * scales out the target immediately. In this case, the scale-in cooldown period stops and doesn't complete. * @return Returns a reference to this object so that method calls can be chained together. */ public TargetTrackingConfiguration withScaleInCooldown(Integer scaleInCooldown) { setScaleInCooldown(scaleInCooldown); return this; } /** *

* The estimated time, in seconds, until a newly launched instance can contribute to the CloudWatch metrics. This * value is used only if the resource is an Auto Scaling group. *

* * @param estimatedInstanceWarmup * The estimated time, in seconds, until a newly launched instance can contribute to the CloudWatch metrics. * This value is used only if the resource is an Auto Scaling group. */ public void setEstimatedInstanceWarmup(Integer estimatedInstanceWarmup) { this.estimatedInstanceWarmup = estimatedInstanceWarmup; } /** *

* The estimated time, in seconds, until a newly launched instance can contribute to the CloudWatch metrics. This * value is used only if the resource is an Auto Scaling group. *

* * @return The estimated time, in seconds, until a newly launched instance can contribute to the CloudWatch metrics. * This value is used only if the resource is an Auto Scaling group. */ public Integer getEstimatedInstanceWarmup() { return this.estimatedInstanceWarmup; } /** *

* The estimated time, in seconds, until a newly launched instance can contribute to the CloudWatch metrics. This * value is used only if the resource is an Auto Scaling group. *

* * @param estimatedInstanceWarmup * The estimated time, in seconds, until a newly launched instance can contribute to the CloudWatch metrics. * This value is used only if the resource is an Auto Scaling group. * @return Returns a reference to this object so that method calls can be chained together. */ public TargetTrackingConfiguration withEstimatedInstanceWarmup(Integer estimatedInstanceWarmup) { setEstimatedInstanceWarmup(estimatedInstanceWarmup); return this; } /** * 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. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getPredefinedScalingMetricSpecification() != null) sb.append("PredefinedScalingMetricSpecification: ").append(getPredefinedScalingMetricSpecification()).append(","); if (getCustomizedScalingMetricSpecification() != null) sb.append("CustomizedScalingMetricSpecification: ").append(getCustomizedScalingMetricSpecification()).append(","); if (getTargetValue() != null) sb.append("TargetValue: ").append(getTargetValue()).append(","); if (getDisableScaleIn() != null) sb.append("DisableScaleIn: ").append(getDisableScaleIn()).append(","); if (getScaleOutCooldown() != null) sb.append("ScaleOutCooldown: ").append(getScaleOutCooldown()).append(","); if (getScaleInCooldown() != null) sb.append("ScaleInCooldown: ").append(getScaleInCooldown()).append(","); if (getEstimatedInstanceWarmup() != null) sb.append("EstimatedInstanceWarmup: ").append(getEstimatedInstanceWarmup()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof TargetTrackingConfiguration == false) return false; TargetTrackingConfiguration other = (TargetTrackingConfiguration) obj; if (other.getPredefinedScalingMetricSpecification() == null ^ this.getPredefinedScalingMetricSpecification() == null) return false; if (other.getPredefinedScalingMetricSpecification() != null && other.getPredefinedScalingMetricSpecification().equals(this.getPredefinedScalingMetricSpecification()) == false) return false; if (other.getCustomizedScalingMetricSpecification() == null ^ this.getCustomizedScalingMetricSpecification() == null) return false; if (other.getCustomizedScalingMetricSpecification() != null && other.getCustomizedScalingMetricSpecification().equals(this.getCustomizedScalingMetricSpecification()) == false) return false; if (other.getTargetValue() == null ^ this.getTargetValue() == null) return false; if (other.getTargetValue() != null && other.getTargetValue().equals(this.getTargetValue()) == false) return false; if (other.getDisableScaleIn() == null ^ this.getDisableScaleIn() == null) return false; if (other.getDisableScaleIn() != null && other.getDisableScaleIn().equals(this.getDisableScaleIn()) == false) return false; if (other.getScaleOutCooldown() == null ^ this.getScaleOutCooldown() == null) return false; if (other.getScaleOutCooldown() != null && other.getScaleOutCooldown().equals(this.getScaleOutCooldown()) == false) return false; if (other.getScaleInCooldown() == null ^ this.getScaleInCooldown() == null) return false; if (other.getScaleInCooldown() != null && other.getScaleInCooldown().equals(this.getScaleInCooldown()) == false) return false; if (other.getEstimatedInstanceWarmup() == null ^ this.getEstimatedInstanceWarmup() == null) return false; if (other.getEstimatedInstanceWarmup() != null && other.getEstimatedInstanceWarmup().equals(this.getEstimatedInstanceWarmup()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getPredefinedScalingMetricSpecification() == null) ? 0 : getPredefinedScalingMetricSpecification().hashCode()); hashCode = prime * hashCode + ((getCustomizedScalingMetricSpecification() == null) ? 0 : getCustomizedScalingMetricSpecification().hashCode()); hashCode = prime * hashCode + ((getTargetValue() == null) ? 0 : getTargetValue().hashCode()); hashCode = prime * hashCode + ((getDisableScaleIn() == null) ? 0 : getDisableScaleIn().hashCode()); hashCode = prime * hashCode + ((getScaleOutCooldown() == null) ? 0 : getScaleOutCooldown().hashCode()); hashCode = prime * hashCode + ((getScaleInCooldown() == null) ? 0 : getScaleInCooldown().hashCode()); hashCode = prime * hashCode + ((getEstimatedInstanceWarmup() == null) ? 0 : getEstimatedInstanceWarmup().hashCode()); return hashCode; } @Override public TargetTrackingConfiguration clone() { try { return (TargetTrackingConfiguration) super.clone(); } catch (CloneNotSupportedException e) { throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e); } } @com.amazonaws.annotation.SdkInternalApi @Override public void marshall(ProtocolMarshaller protocolMarshaller) { com.amazonaws.services.autoscalingplans.model.transform.TargetTrackingConfigurationMarshaller.getInstance().marshall(this, protocolMarshaller); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy