/** * 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 a utilization metric of an Amazon Elastic Block Store (Amazon EBS) * volume.

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.

See * Also:

AWS * API Reference

*/ class EBSUtilizationMetric { public: AWS_COMPUTEOPTIMIZER_API EBSUtilizationMetric(); AWS_COMPUTEOPTIMIZER_API EBSUtilizationMetric(Aws::Utils::Json::JsonView jsonValue); AWS_COMPUTEOPTIMIZER_API EBSUtilizationMetric& 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:

  • VolumeReadOpsPerSecond - The * completed read operations per second from the volume in a specified period of * time.

    Unit: Count

  • VolumeWriteOpsPerSecond * - The completed write operations per second to the volume in a specified period * of time.

    Unit: Count

  • * VolumeReadBytesPerSecond - The bytes read per second from the * volume in a specified period of time.

    Unit: Bytes

  • * VolumeWriteBytesPerSecond - The bytes written to the volume in a * specified period of time.

    Unit: Bytes

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

The name of the utilization metric.

The following utilization metrics * are available:

  • VolumeReadOpsPerSecond - The * completed read operations per second from the volume in a specified period of * time.

    Unit: Count

  • VolumeWriteOpsPerSecond * - The completed write operations per second to the volume in a specified period * of time.

    Unit: Count

  • * VolumeReadBytesPerSecond - The bytes read per second from the * volume in a specified period of time.

    Unit: Bytes

  • * VolumeWriteBytesPerSecond - The bytes written to the volume in a * specified period of time.

    Unit: Bytes

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

The name of the utilization metric.

The following utilization metrics * are available:

  • VolumeReadOpsPerSecond - The * completed read operations per second from the volume in a specified period of * time.

    Unit: Count

  • VolumeWriteOpsPerSecond * - The completed write operations per second to the volume in a specified period * of time.

    Unit: Count

  • * VolumeReadBytesPerSecond - The bytes read per second from the * volume in a specified period of time.

    Unit: Bytes

  • * VolumeWriteBytesPerSecond - The bytes written to the volume in a * specified period of time.

    Unit: Bytes

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

The name of the utilization metric.

The following utilization metrics * are available:

  • VolumeReadOpsPerSecond - The * completed read operations per second from the volume in a specified period of * time.

    Unit: Count

  • VolumeWriteOpsPerSecond * - The completed write operations per second to the volume in a specified period * of time.

    Unit: Count

  • * VolumeReadBytesPerSecond - The bytes read per second from the * volume in a specified period of time.

    Unit: Bytes

  • * VolumeWriteBytesPerSecond - The bytes written to the volume in a * specified period of time.

    Unit: Bytes

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

The name of the utilization metric.

The following utilization metrics * are available:

  • VolumeReadOpsPerSecond - The * completed read operations per second from the volume in a specified period of * time.

    Unit: Count

  • VolumeWriteOpsPerSecond * - The completed write operations per second to the volume in a specified period * of time.

    Unit: Count

  • * VolumeReadBytesPerSecond - The bytes read per second from the * volume in a specified period of time.

    Unit: Bytes

  • * VolumeWriteBytesPerSecond - The bytes written to the volume in a * specified period of time.

    Unit: Bytes

*/ inline EBSUtilizationMetric& WithName(const EBSMetricName& value) { SetName(value); return *this;} /** *

The name of the utilization metric.

The following utilization metrics * are available:

  • VolumeReadOpsPerSecond - The * completed read operations per second from the volume in a specified period of * time.

    Unit: Count

  • VolumeWriteOpsPerSecond * - The completed write operations per second to the volume in a specified period * of time.

    Unit: Count

  • * VolumeReadBytesPerSecond - The bytes read per second from the * volume in a specified period of time.

    Unit: Bytes

  • * VolumeWriteBytesPerSecond - The bytes written to the volume in a * specified period of time.

    Unit: Bytes

*/ inline EBSUtilizationMetric& WithName(EBSMetricName&& 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 MetricStatistic& 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 MetricStatistic& 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(MetricStatistic&& 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 EBSUtilizationMetric& WithStatistic(const MetricStatistic& 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 EBSUtilizationMetric& WithStatistic(MetricStatistic&& 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 EBSUtilizationMetric& WithValue(double value) { SetValue(value); return *this;} private: EBSMetricName m_name; bool m_nameHasBeenSet = false; MetricStatistic m_statistic; bool m_statisticHasBeenSet = false; double m_value; bool m_valueHasBeenSet = false; }; } // namespace Model } // namespace ComputeOptimizer } // namespace Aws