/*
* Copyright 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.
*/
/*
* Do not modify this file. This file is generated from the application-autoscaling-2016-02-06.normal.json service model.
*/
using System;
using System.Collections.Generic;
using System.Xml.Serialization;
using System.Text;
using System.IO;
using System.Net;
using Amazon.Runtime;
using Amazon.Runtime.Internal;
namespace Amazon.ApplicationAutoScaling.Model
{
///
/// 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 Building
/// dashboards with CloudWatch in the Application Auto Scaling User Guide.
///
///
public partial class PredefinedMetricSpecification
{
private MetricType _predefinedMetricType;
private string _resourceLabel;
///
/// Gets and sets the property PredefinedMetricType.
///
/// The metric type. The ALBRequestCountPerTarget
metric type applies only
/// to Spot Fleets and ECS services.
///
///
[AWSProperty(Required=true)]
public MetricType PredefinedMetricType
{
get { return this._predefinedMetricType; }
set { this._predefinedMetricType = value; }
}
// Check to see if PredefinedMetricType property is set
internal bool IsSetPredefinedMetricType()
{
return this._predefinedMetricType != null;
}
///
/// Gets and sets the property 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.
///
///
[AWSProperty(Min=1, Max=1023)]
public string ResourceLabel
{
get { return this._resourceLabel; }
set { this._resourceLabel = value; }
}
// Check to see if ResourceLabel property is set
internal bool IsSetResourceLabel()
{
return this._resourceLabel != null;
}
}
}