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

com.amazonaws.services.applicationautoscaling.model.PredefinedMetricSpecification Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS Application Auto Scaling module holds the client classes that are used for communicating with AWS Application Auto Scaling 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.applicationautoscaling.model;

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

/**
 * 

* Represents a predefined metric for a target tracking scaling policy to use with Application Auto Scaling. *

*

* Only the Amazon Web Services that you're using send metrics to Amazon CloudWatch. To determine whether a desired * metric already exists by looking up its namespace and dimension using the CloudWatch metrics dashboard in the * console, follow the procedure in Monitor your * resources using CloudWatch in the Application Auto Scaling User Guide. *

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

* The metric type. The ALBRequestCountPerTarget metric type applies only to Spot Fleets and ECS * services. *

*/ private String predefinedMetricType; /** *

* Identifies the resource associated with the metric type. You can't specify a resource label unless the metric * type is ALBRequestCountPerTarget and there is a target group attached to the Spot Fleet or ECS * service. *

*

* You create the resource label by appending the final portion of the load balancer ARN and the final portion of * the target group ARN into a single value, separated by a forward slash (/). The format of the resource label is: *

*

* app/my-alb/778d41231b141a0f/targetgroup/my-alb-target-group/943f017f100becff. *

*

* Where: *

*
    *
  • *

    * app/<load-balancer-name>/<load-balancer-id> is the final portion of the load balancer ARN *

    *
  • *
  • *

    * targetgroup/<target-group-name>/<target-group-id> is the final portion of the target group ARN. *

    *
  • *
*

* To find the ARN for an Application Load Balancer, use the DescribeLoadBalancers API operation. To find the ARN for the target group, use the DescribeTargetGroups API operation. *

*/ private String resourceLabel; /** *

* The metric type. The ALBRequestCountPerTarget metric type applies only to Spot Fleets and ECS * services. *

* * @param predefinedMetricType * The metric type. The ALBRequestCountPerTarget metric type applies only to Spot Fleets and ECS * services. * @see MetricType */ public void setPredefinedMetricType(String predefinedMetricType) { this.predefinedMetricType = predefinedMetricType; } /** *

* The metric type. The ALBRequestCountPerTarget metric type applies only to Spot Fleets and ECS * services. *

* * @return The metric type. The ALBRequestCountPerTarget metric type applies only to Spot Fleets and * ECS services. * @see MetricType */ public String getPredefinedMetricType() { return this.predefinedMetricType; } /** *

* The metric type. The ALBRequestCountPerTarget metric type applies only to Spot Fleets and ECS * services. *

* * @param predefinedMetricType * The metric type. The ALBRequestCountPerTarget metric type applies only to Spot Fleets and ECS * services. * @return Returns a reference to this object so that method calls can be chained together. * @see MetricType */ public PredefinedMetricSpecification withPredefinedMetricType(String predefinedMetricType) { setPredefinedMetricType(predefinedMetricType); return this; } /** *

* The metric type. The ALBRequestCountPerTarget metric type applies only to Spot Fleets and ECS * services. *

* * @param predefinedMetricType * The metric type. The ALBRequestCountPerTarget metric type applies only to Spot Fleets and ECS * services. * @see MetricType */ public void setPredefinedMetricType(MetricType predefinedMetricType) { withPredefinedMetricType(predefinedMetricType); } /** *

* The metric type. The ALBRequestCountPerTarget metric type applies only to Spot Fleets and ECS * services. *

* * @param predefinedMetricType * The metric type. The ALBRequestCountPerTarget metric type applies only to Spot Fleets and ECS * services. * @return Returns a reference to this object so that method calls can be chained together. * @see MetricType */ public PredefinedMetricSpecification withPredefinedMetricType(MetricType predefinedMetricType) { this.predefinedMetricType = predefinedMetricType.toString(); return this; } /** *

* Identifies the resource associated with the metric type. You can't specify a resource label unless the metric * type is ALBRequestCountPerTarget and there is a target group attached to the Spot Fleet or ECS * service. *

*

* You create the resource label by appending the final portion of the load balancer ARN and the final portion of * the target group ARN into a single value, separated by a forward slash (/). The format of the resource label is: *

*

* app/my-alb/778d41231b141a0f/targetgroup/my-alb-target-group/943f017f100becff. *

*

* Where: *

*
    *
  • *

    * app/<load-balancer-name>/<load-balancer-id> is the final portion of the load balancer ARN *

    *
  • *
  • *

    * targetgroup/<target-group-name>/<target-group-id> is the final portion of the target group ARN. *

    *
  • *
*

* To find the ARN for an Application Load Balancer, use the DescribeLoadBalancers API operation. To find the ARN for the target group, use the DescribeTargetGroups API operation. *

* * @param resourceLabel * Identifies the resource associated with the metric type. You can't specify a resource label unless the * metric type is ALBRequestCountPerTarget and there is a target group attached to the Spot * Fleet or ECS service.

*

* You create the resource label by appending the final portion of the load balancer ARN and the final * portion of the target group ARN into a single value, separated by a forward slash (/). The format of the * resource label is: *

*

* app/my-alb/778d41231b141a0f/targetgroup/my-alb-target-group/943f017f100becff. *

*

* Where: *

*
    *
  • *

    * app/<load-balancer-name>/<load-balancer-id> is the final portion of the load balancer ARN *

    *
  • *
  • *

    * targetgroup/<target-group-name>/<target-group-id> is the final portion of the target group * ARN. *

    *
  • *
*

* To find the ARN for an Application Load Balancer, use the DescribeLoadBalancers API operation. To find the ARN for the target group, use the DescribeTargetGroups API operation. */ public void setResourceLabel(String resourceLabel) { this.resourceLabel = resourceLabel; } /** *

* Identifies the resource associated with the metric type. You can't specify a resource label unless the metric * type is ALBRequestCountPerTarget and there is a target group attached to the Spot Fleet or ECS * service. *

*

* You create the resource label by appending the final portion of the load balancer ARN and the final portion of * the target group ARN into a single value, separated by a forward slash (/). The format of the resource label is: *

*

* app/my-alb/778d41231b141a0f/targetgroup/my-alb-target-group/943f017f100becff. *

*

* Where: *

*
    *
  • *

    * app/<load-balancer-name>/<load-balancer-id> is the final portion of the load balancer ARN *

    *
  • *
  • *

    * targetgroup/<target-group-name>/<target-group-id> is the final portion of the target group ARN. *

    *
  • *
*

* To find the ARN for an Application Load Balancer, use the DescribeLoadBalancers API operation. To find the ARN for the target group, use the DescribeTargetGroups API operation. *

* * @return Identifies the resource associated with the metric type. You can't specify a resource label unless the * metric type is ALBRequestCountPerTarget and there is a target group attached to the Spot * Fleet or ECS service.

*

* You create the resource label by appending the final portion of the load balancer ARN and the final * portion of the target group ARN into a single value, separated by a forward slash (/). The format of the * resource label is: *

*

* app/my-alb/778d41231b141a0f/targetgroup/my-alb-target-group/943f017f100becff. *

*

* Where: *

*
    *
  • *

    * app/<load-balancer-name>/<load-balancer-id> is the final portion of the load balancer ARN *

    *
  • *
  • *

    * targetgroup/<target-group-name>/<target-group-id> is the final portion of the target group * ARN. *

    *
  • *
*

* To find the ARN for an Application Load Balancer, use the DescribeLoadBalancers API operation. To find the ARN for the target group, use the DescribeTargetGroups API operation. */ public String getResourceLabel() { return this.resourceLabel; } /** *

* Identifies the resource associated with the metric type. You can't specify a resource label unless the metric * type is ALBRequestCountPerTarget and there is a target group attached to the Spot Fleet or ECS * service. *

*

* You create the resource label by appending the final portion of the load balancer ARN and the final portion of * the target group ARN into a single value, separated by a forward slash (/). The format of the resource label is: *

*

* app/my-alb/778d41231b141a0f/targetgroup/my-alb-target-group/943f017f100becff. *

*

* Where: *

*
    *
  • *

    * app/<load-balancer-name>/<load-balancer-id> is the final portion of the load balancer ARN *

    *
  • *
  • *

    * targetgroup/<target-group-name>/<target-group-id> is the final portion of the target group ARN. *

    *
  • *
*

* To find the ARN for an Application Load Balancer, use the DescribeLoadBalancers API operation. To find the ARN for the target group, use the DescribeTargetGroups API operation. *

* * @param resourceLabel * Identifies the resource associated with the metric type. You can't specify a resource label unless the * metric type is ALBRequestCountPerTarget and there is a target group attached to the Spot * Fleet or ECS service.

*

* You create the resource label by appending the final portion of the load balancer ARN and the final * portion of the target group ARN into a single value, separated by a forward slash (/). The format of the * resource label is: *

*

* app/my-alb/778d41231b141a0f/targetgroup/my-alb-target-group/943f017f100becff. *

*

* Where: *

*
    *
  • *

    * app/<load-balancer-name>/<load-balancer-id> is the final portion of the load balancer ARN *

    *
  • *
  • *

    * targetgroup/<target-group-name>/<target-group-id> is the final portion of the target group * ARN. *

    *
  • *
*

* To find the ARN for an Application Load Balancer, use the DescribeLoadBalancers API operation. To find the ARN for the target group, use the DescribeTargetGroups API operation. * @return Returns a reference to this object so that method calls can be chained together. */ public PredefinedMetricSpecification withResourceLabel(String resourceLabel) { setResourceLabel(resourceLabel); 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 (getPredefinedMetricType() != null) sb.append("PredefinedMetricType: ").append(getPredefinedMetricType()).append(","); if (getResourceLabel() != null) sb.append("ResourceLabel: ").append(getResourceLabel()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof PredefinedMetricSpecification == false) return false; PredefinedMetricSpecification other = (PredefinedMetricSpecification) obj; if (other.getPredefinedMetricType() == null ^ this.getPredefinedMetricType() == null) return false; if (other.getPredefinedMetricType() != null && other.getPredefinedMetricType().equals(this.getPredefinedMetricType()) == false) return false; if (other.getResourceLabel() == null ^ this.getResourceLabel() == null) return false; if (other.getResourceLabel() != null && other.getResourceLabel().equals(this.getResourceLabel()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getPredefinedMetricType() == null) ? 0 : getPredefinedMetricType().hashCode()); hashCode = prime * hashCode + ((getResourceLabel() == null) ? 0 : getResourceLabel().hashCode()); return hashCode; } @Override public PredefinedMetricSpecification clone() { try { return (PredefinedMetricSpecification) 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.applicationautoscaling.model.transform.PredefinedMetricSpecificationMarshaller.getInstance().marshall(this, protocolMarshaller); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy