/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include namespace Aws { namespace Utils { namespace Json { class JsonValue; class JsonView; } // namespace Json } // namespace Utils namespace ComputeOptimizer { namespace Model { /** *

Describes the utilization metric of an Amazon ECS service.

To * determine the performance difference between your current Amazon ECS service and * the recommended option, compare the utilization metric data of your service * against its projected utilization metric data.

See Also:

AWS * API Reference

*/ class ECSServiceUtilizationMetric { public: AWS_COMPUTEOPTIMIZER_API ECSServiceUtilizationMetric(); AWS_COMPUTEOPTIMIZER_API ECSServiceUtilizationMetric(Aws::Utils::Json::JsonView jsonValue); AWS_COMPUTEOPTIMIZER_API ECSServiceUtilizationMetric& operator=(Aws::Utils::Json::JsonView jsonValue); AWS_COMPUTEOPTIMIZER_API Aws::Utils::Json::JsonValue Jsonize() const; /** *

The name of the utilization metric.

The following utilization * metrics are available:

  • Cpu — The amount of CPU * capacity that's used in the service.

  • Memory — * The amount of memory that's used in the service.

*/ inline const ECSServiceMetricName& GetName() const{ return m_name; } /** *

The name of the utilization metric.

The following utilization * metrics are available:

  • Cpu — The amount of CPU * capacity that's used in the service.

  • Memory — * The amount of memory that's used in the service.

*/ inline bool NameHasBeenSet() const { return m_nameHasBeenSet; } /** *

The name of the utilization metric.

The following utilization * metrics are available:

  • Cpu — The amount of CPU * capacity that's used in the service.

  • Memory — * The amount of memory that's used in the service.

*/ inline void SetName(const ECSServiceMetricName& value) { m_nameHasBeenSet = true; m_name = value; } /** *

The name of the utilization metric.

The following utilization * metrics are available:

  • Cpu — The amount of CPU * capacity that's used in the service.

  • Memory — * The amount of memory that's used in the service.

*/ inline void SetName(ECSServiceMetricName&& value) { m_nameHasBeenSet = true; m_name = std::move(value); } /** *

The name of the utilization metric.

The following utilization * metrics are available:

  • Cpu — The amount of CPU * capacity that's used in the service.

  • Memory — * The amount of memory that's used in the service.

*/ inline ECSServiceUtilizationMetric& WithName(const ECSServiceMetricName& value) { SetName(value); return *this;} /** *

The name of the utilization metric.

The following utilization * metrics are available:

  • Cpu — The amount of CPU * capacity that's used in the service.

  • Memory — * The amount of memory that's used in the service.

*/ inline ECSServiceUtilizationMetric& WithName(ECSServiceMetricName&& value) { SetName(std::move(value)); return *this;} /** *

The statistic of the utilization metric.

The Compute Optimizer API, * Command Line Interface (CLI), and SDKs return utilization metrics using only the * Maximum statistic, which is the highest value observed during the * specified period.

The Compute Optimizer console displays graphs for some * utilization metrics using the Average statistic, which is the value * of Sum / SampleCount during the specified period. For * more information, see Viewing * resource recommendations in the Compute Optimizer User Guide. You can * also get averaged utilization metric data for your resources using Amazon * CloudWatch. For more information, see the Amazon * CloudWatch User Guide.

*/ inline const ECSServiceMetricStatistic& GetStatistic() const{ return m_statistic; } /** *

The statistic of the utilization metric.

The Compute Optimizer API, * Command Line Interface (CLI), and SDKs return utilization metrics using only the * Maximum statistic, which is the highest value observed during the * specified period.

The Compute Optimizer console displays graphs for some * utilization metrics using the Average statistic, which is the value * of Sum / SampleCount during the specified period. For * more information, see Viewing * resource recommendations in the Compute Optimizer User Guide. You can * also get averaged utilization metric data for your resources using Amazon * CloudWatch. For more information, see the Amazon * CloudWatch User Guide.

*/ inline bool StatisticHasBeenSet() const { return m_statisticHasBeenSet; } /** *

The statistic of the utilization metric.

The Compute Optimizer API, * Command Line Interface (CLI), and SDKs return utilization metrics using only the * Maximum statistic, which is the highest value observed during the * specified period.

The Compute Optimizer console displays graphs for some * utilization metrics using the Average statistic, which is the value * of Sum / SampleCount during the specified period. For * more information, see Viewing * resource recommendations in the Compute Optimizer User Guide. You can * also get averaged utilization metric data for your resources using Amazon * CloudWatch. For more information, see the Amazon * CloudWatch User Guide.

*/ inline void SetStatistic(const ECSServiceMetricStatistic& value) { m_statisticHasBeenSet = true; m_statistic = value; } /** *

The statistic of the utilization metric.

The Compute Optimizer API, * Command Line Interface (CLI), and SDKs return utilization metrics using only the * Maximum statistic, which is the highest value observed during the * specified period.

The Compute Optimizer console displays graphs for some * utilization metrics using the Average statistic, which is the value * of Sum / SampleCount during the specified period. For * more information, see Viewing * resource recommendations in the Compute Optimizer User Guide. You can * also get averaged utilization metric data for your resources using Amazon * CloudWatch. For more information, see the Amazon * CloudWatch User Guide.

*/ inline void SetStatistic(ECSServiceMetricStatistic&& value) { m_statisticHasBeenSet = true; m_statistic = std::move(value); } /** *

The statistic of the utilization metric.

The Compute Optimizer API, * Command Line Interface (CLI), and SDKs return utilization metrics using only the * Maximum statistic, which is the highest value observed during the * specified period.

The Compute Optimizer console displays graphs for some * utilization metrics using the Average statistic, which is the value * of Sum / SampleCount during the specified period. For * more information, see Viewing * resource recommendations in the Compute Optimizer User Guide. You can * also get averaged utilization metric data for your resources using Amazon * CloudWatch. For more information, see the Amazon * CloudWatch User Guide.

*/ inline ECSServiceUtilizationMetric& WithStatistic(const ECSServiceMetricStatistic& value) { SetStatistic(value); return *this;} /** *

The statistic of the utilization metric.

The Compute Optimizer API, * Command Line Interface (CLI), and SDKs return utilization metrics using only the * Maximum statistic, which is the highest value observed during the * specified period.

The Compute Optimizer console displays graphs for some * utilization metrics using the Average statistic, which is the value * of Sum / SampleCount during the specified period. For * more information, see Viewing * resource recommendations in the Compute Optimizer User Guide. You can * also get averaged utilization metric data for your resources using Amazon * CloudWatch. For more information, see the Amazon * CloudWatch User Guide.

*/ inline ECSServiceUtilizationMetric& WithStatistic(ECSServiceMetricStatistic&& value) { SetStatistic(std::move(value)); return *this;} /** *

The value of the utilization metric.

*/ inline double GetValue() const{ return m_value; } /** *

The value of the utilization metric.

*/ inline bool ValueHasBeenSet() const { return m_valueHasBeenSet; } /** *

The value of the utilization metric.

*/ inline void SetValue(double value) { m_valueHasBeenSet = true; m_value = value; } /** *

The value of the utilization metric.

*/ inline ECSServiceUtilizationMetric& WithValue(double value) { SetValue(value); return *this;} private: ECSServiceMetricName m_name; bool m_nameHasBeenSet = false; ECSServiceMetricStatistic m_statistic; bool m_statisticHasBeenSet = false; double m_value; bool m_valueHasBeenSet = false; }; } // namespace Model } // namespace ComputeOptimizer } // namespace Aws