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

Describes a projected utilization metric of a recommendation option, such as * an Amazon EC2 instance. This represents the projected utilization of a * recommendation option had you used that resource during the analyzed period.

*

Compare the utilization metric data of your resource against its projected * utilization metric data to determine the performance difference between your * current resource and the recommended option.

The Cpu * and Memory metrics are the only projected utilization metrics * returned when you run the GetEC2RecommendationProjectedMetrics action. * Additionally, the Memory metric is returned only for resources that * have the unified CloudWatch agent installed on them. For more information, see * Enabling * Memory Utilization with the CloudWatch Agent.

See * Also:

AWS * API Reference

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

The name of the projected utilization metric.

The following projected * utilization metrics are returned:

  • Cpu - The * projected percentage of allocated EC2 compute units that would be in use on the * recommendation option had you used that resource during the analyzed period. * This metric identifies the processing power required to run an application on * the recommendation option.

    Depending on the instance type, tools in your * operating system can show a lower percentage than CloudWatch when the instance * is not allocated a full processor core.

    Units: Percent

  • * Memory - The percentage of memory that would be in use on the * recommendation option had you used that resource during the analyzed period. * This metric identifies the amount of memory required to run an application on * the recommendation option.

    Units: Percent

    The * Memory metric is returned only for resources that have the unified * CloudWatch agent installed on them. For more information, see Enabling * Memory Utilization with the CloudWatch Agent.

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

The name of the projected utilization metric.

The following projected * utilization metrics are returned:

  • Cpu - The * projected percentage of allocated EC2 compute units that would be in use on the * recommendation option had you used that resource during the analyzed period. * This metric identifies the processing power required to run an application on * the recommendation option.

    Depending on the instance type, tools in your * operating system can show a lower percentage than CloudWatch when the instance * is not allocated a full processor core.

    Units: Percent

  • * Memory - The percentage of memory that would be in use on the * recommendation option had you used that resource during the analyzed period. * This metric identifies the amount of memory required to run an application on * the recommendation option.

    Units: Percent

    The * Memory metric is returned only for resources that have the unified * CloudWatch agent installed on them. For more information, see Enabling * Memory Utilization with the CloudWatch Agent.

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

The name of the projected utilization metric.

The following projected * utilization metrics are returned:

  • Cpu - The * projected percentage of allocated EC2 compute units that would be in use on the * recommendation option had you used that resource during the analyzed period. * This metric identifies the processing power required to run an application on * the recommendation option.

    Depending on the instance type, tools in your * operating system can show a lower percentage than CloudWatch when the instance * is not allocated a full processor core.

    Units: Percent

  • * Memory - The percentage of memory that would be in use on the * recommendation option had you used that resource during the analyzed period. * This metric identifies the amount of memory required to run an application on * the recommendation option.

    Units: Percent

    The * Memory metric is returned only for resources that have the unified * CloudWatch agent installed on them. For more information, see Enabling * Memory Utilization with the CloudWatch Agent.

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

The name of the projected utilization metric.

The following projected * utilization metrics are returned:

  • Cpu - The * projected percentage of allocated EC2 compute units that would be in use on the * recommendation option had you used that resource during the analyzed period. * This metric identifies the processing power required to run an application on * the recommendation option.

    Depending on the instance type, tools in your * operating system can show a lower percentage than CloudWatch when the instance * is not allocated a full processor core.

    Units: Percent

  • * Memory - The percentage of memory that would be in use on the * recommendation option had you used that resource during the analyzed period. * This metric identifies the amount of memory required to run an application on * the recommendation option.

    Units: Percent

    The * Memory metric is returned only for resources that have the unified * CloudWatch agent installed on them. For more information, see Enabling * Memory Utilization with the CloudWatch Agent.

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

The name of the projected utilization metric.

The following projected * utilization metrics are returned:

  • Cpu - The * projected percentage of allocated EC2 compute units that would be in use on the * recommendation option had you used that resource during the analyzed period. * This metric identifies the processing power required to run an application on * the recommendation option.

    Depending on the instance type, tools in your * operating system can show a lower percentage than CloudWatch when the instance * is not allocated a full processor core.

    Units: Percent

  • * Memory - The percentage of memory that would be in use on the * recommendation option had you used that resource during the analyzed period. * This metric identifies the amount of memory required to run an application on * the recommendation option.

    Units: Percent

    The * Memory metric is returned only for resources that have the unified * CloudWatch agent installed on them. For more information, see Enabling * Memory Utilization with the CloudWatch Agent.

*/ inline ProjectedMetric& WithName(const MetricName& value) { SetName(value); return *this;} /** *

The name of the projected utilization metric.

The following projected * utilization metrics are returned:

  • Cpu - The * projected percentage of allocated EC2 compute units that would be in use on the * recommendation option had you used that resource during the analyzed period. * This metric identifies the processing power required to run an application on * the recommendation option.

    Depending on the instance type, tools in your * operating system can show a lower percentage than CloudWatch when the instance * is not allocated a full processor core.

    Units: Percent

  • * Memory - The percentage of memory that would be in use on the * recommendation option had you used that resource during the analyzed period. * This metric identifies the amount of memory required to run an application on * the recommendation option.

    Units: Percent

    The * Memory metric is returned only for resources that have the unified * CloudWatch agent installed on them. For more information, see Enabling * Memory Utilization with the CloudWatch Agent.

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

The timestamps of the projected utilization metric.

*/ inline const Aws::Vector& GetTimestamps() const{ return m_timestamps; } /** *

The timestamps of the projected utilization metric.

*/ inline bool TimestampsHasBeenSet() const { return m_timestampsHasBeenSet; } /** *

The timestamps of the projected utilization metric.

*/ inline void SetTimestamps(const Aws::Vector& value) { m_timestampsHasBeenSet = true; m_timestamps = value; } /** *

The timestamps of the projected utilization metric.

*/ inline void SetTimestamps(Aws::Vector&& value) { m_timestampsHasBeenSet = true; m_timestamps = std::move(value); } /** *

The timestamps of the projected utilization metric.

*/ inline ProjectedMetric& WithTimestamps(const Aws::Vector& value) { SetTimestamps(value); return *this;} /** *

The timestamps of the projected utilization metric.

*/ inline ProjectedMetric& WithTimestamps(Aws::Vector&& value) { SetTimestamps(std::move(value)); return *this;} /** *

The timestamps of the projected utilization metric.

*/ inline ProjectedMetric& AddTimestamps(const Aws::Utils::DateTime& value) { m_timestampsHasBeenSet = true; m_timestamps.push_back(value); return *this; } /** *

The timestamps of the projected utilization metric.

*/ inline ProjectedMetric& AddTimestamps(Aws::Utils::DateTime&& value) { m_timestampsHasBeenSet = true; m_timestamps.push_back(std::move(value)); return *this; } /** *

The values of the projected utilization metrics.

*/ inline const Aws::Vector& GetValues() const{ return m_values; } /** *

The values of the projected utilization metrics.

*/ inline bool ValuesHasBeenSet() const { return m_valuesHasBeenSet; } /** *

The values of the projected utilization metrics.

*/ inline void SetValues(const Aws::Vector& value) { m_valuesHasBeenSet = true; m_values = value; } /** *

The values of the projected utilization metrics.

*/ inline void SetValues(Aws::Vector&& value) { m_valuesHasBeenSet = true; m_values = std::move(value); } /** *

The values of the projected utilization metrics.

*/ inline ProjectedMetric& WithValues(const Aws::Vector& value) { SetValues(value); return *this;} /** *

The values of the projected utilization metrics.

*/ inline ProjectedMetric& WithValues(Aws::Vector&& value) { SetValues(std::move(value)); return *this;} /** *

The values of the projected utilization metrics.

*/ inline ProjectedMetric& AddValues(double value) { m_valuesHasBeenSet = true; m_values.push_back(value); return *this; } private: MetricName m_name; bool m_nameHasBeenSet = false; Aws::Vector m_timestamps; bool m_timestampsHasBeenSet = false; Aws::Vector m_values; bool m_valuesHasBeenSet = false; }; } // namespace Model } // namespace ComputeOptimizer } // namespace Aws