/*
* 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 autoscaling-plans-2018-01-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.AutoScalingPlans.Model
{
///
/// Represents a predefined metric that can be used for predictive scaling.
///
///
///
/// After creating your scaling plan, you can use the AWS Auto Scaling console to visualize
/// forecasts for the specified metric. For more information, see View
/// Scaling Information for a Resource in the AWS Auto Scaling User Guide.
///
///
public partial class PredefinedLoadMetricSpecification
{
private LoadMetricType _predefinedLoadMetricType;
private string _resourceLabel;
///
/// Gets and sets the property PredefinedLoadMetricType.
///
/// The metric type.
///
///
[AWSProperty(Required=true)]
public LoadMetricType PredefinedLoadMetricType
{
get { return this._predefinedLoadMetricType; }
set { this._predefinedLoadMetricType = value; }
}
// Check to see if PredefinedLoadMetricType property is set
internal bool IsSetPredefinedLoadMetricType()
{
return this._predefinedLoadMetricType != 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 ALBTargetGroupRequestCount
and there
/// is a target group for an Application Load Balancer attached to the Auto Scaling group.
///
///
///
/// 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 is app/<load-balancer-name>/<load-balancer-id>/targetgroup/<target-group-name>/<target-group-id>,
/// 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.
///
///
///
/// This is an example: app/EC2Co-EcsEl-1TKLTMITMM0EO/f37c06a68c1748aa/targetgroup/EC2Co-Defau-LDNM7Q3ZH1ZN/6d4ea56ca2d6a18d.
///
///
///
/// 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;
}
}
}