@Generated(value="software.amazon.awssdk:codegen") public final class InstanceRecommendationOption extends Object implements SdkPojo, Serializable, ToCopyableBuilder<InstanceRecommendationOption.Builder,InstanceRecommendationOption>
Describes a recommendation option for an Amazon EC2 instance.
| Modifier and Type | Class and Description |
|---|---|
static interface |
InstanceRecommendationOption.Builder |
| Modifier and Type | Method and Description |
|---|---|
static InstanceRecommendationOption.Builder |
builder() |
boolean |
equals(Object obj) |
boolean |
equalsBySdkFields(Object obj) |
<T> Optional<T> |
getValueForField(String fieldName,
Class<T> clazz) |
int |
hashCode() |
boolean |
hasPlatformDifferences()
For responses, this returns true if the service returned a value for the PlatformDifferences property.
|
boolean |
hasProjectedUtilizationMetrics()
For responses, this returns true if the service returned a value for the ProjectedUtilizationMetrics property.
|
String |
instanceType()
The instance type of the instance recommendation.
|
MigrationEffort |
migrationEffort()
The level of effort required to migrate from the current instance type to the recommended instance type.
|
String |
migrationEffortAsString()
The level of effort required to migrate from the current instance type to the recommended instance type.
|
Double |
performanceRisk()
The performance risk of the instance recommendation option.
|
List<PlatformDifference> |
platformDifferences()
Describes the configuration differences between the current instance and the recommended instance type.
|
List<String> |
platformDifferencesAsStrings()
Describes the configuration differences between the current instance and the recommended instance type.
|
List<UtilizationMetric> |
projectedUtilizationMetrics()
An array of objects that describe the projected utilization metrics of the instance recommendation option.
|
Integer |
rank()
The rank of the instance recommendation option.
|
SavingsOpportunity |
savingsOpportunity()
An object that describes the savings opportunity for the instance recommendation option.
|
List<SdkField<?>> |
sdkFields() |
static Class<? extends InstanceRecommendationOption.Builder> |
serializableBuilderClass() |
InstanceRecommendationOption.Builder |
toBuilder() |
String |
toString()
Returns a string representation of this object.
|
clone, finalize, getClass, notify, notifyAll, wait, wait, waitcopypublic final String instanceType()
The instance type of the instance recommendation.
public final boolean hasProjectedUtilizationMetrics()
isEmpty() method on the
property). This is useful because the SDK will never return a null collection or map, but you may need to
differentiate between the service returning nothing (or null) and the service returning an empty collection or
map. For requests, this returns true if a value for the property was specified in the request builder, and false
if a value was not specified.public final List<UtilizationMetric> projectedUtilizationMetrics()
An array of objects that describe the projected utilization metrics of the instance recommendation option.
The Cpu and Memory metrics are the only projected utilization metrics returned.
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.
Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
This method will never return null. If you would like to know whether the service returned this field (so that
you can differentiate between null and empty), you can use the hasProjectedUtilizationMetrics() method.
The Cpu and Memory metrics are the only projected utilization metrics returned.
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.
public final List<PlatformDifference> platformDifferences()
Describes the configuration differences between the current instance and the recommended instance type. You should consider the configuration differences before migrating your workloads from the current instance to the recommended instance type. The Change the instance type guide for Linux and Change the instance type guide for Windows provide general guidance for getting started with an instance migration.
Platform differences include:
Hypervisor — The hypervisor of the recommended instance type is different than that of the
current instance. For example, the recommended instance type uses a Nitro hypervisor and the current instance
uses a Xen hypervisor. The differences that you should consider between these hypervisors are covered in the Nitro Hypervisor section of the Amazon EC2 frequently
asked questions. For more information, see Instances
built on the Nitro System in the Amazon EC2 User Guide for Linux, or Instances
built on the Nitro System in the Amazon EC2 User Guide for Windows.
NetworkInterface — The network interface of the recommended instance type is different than
that of the current instance. For example, the recommended instance type supports enhanced networking and the
current instance might not. To enable enhanced networking for the recommended instance type, you must install the
Elastic Network Adapter (ENA) driver or the Intel 82599 Virtual Function driver. For more information, see
Networking and storage features and Enhanced networking on
Linux in the Amazon EC2 User Guide for Linux, or Networking and storage features and Enhanced networking on
Windows in the Amazon EC2 User Guide for Windows.
StorageInterface — The storage interface of the recommended instance type is different than
that of the current instance. For example, the recommended instance type uses an NVMe storage interface and the
current instance does not. To access NVMe volumes for the recommended instance type, you will need to install or
upgrade the NVMe driver. For more information, see Networking and storage features and Amazon EBS and NVMe on Linux
instances in the Amazon EC2 User Guide for Linux, or Networking and storage features and Amazon EBS and NVMe on
Windows instances in the Amazon EC2 User Guide for Windows.
InstanceStoreAvailability — The recommended instance type does not support instance store
volumes and the current instance does. Before migrating, you might need to back up the data on your instance
store volumes if you want to preserve them. For more information, see How do I back up an
instance store volume on my Amazon EC2 instance to Amazon EBS? in the Amazon Web Services Premium Support
Knowledge Base. For more information, see Networking and storage features and Amazon EC2 instance store in
the Amazon EC2 User Guide for Linux, or see Networking and storage features and Amazon EC2 instance store
in the Amazon EC2 User Guide for Windows.
VirtualizationType — The recommended instance type uses the hardware virtual machine (HVM)
virtualization type and the current instance uses the paravirtual (PV) virtualization type. For more information
about the differences between these virtualization types, see Linux AMI virtualization
types in the Amazon EC2 User Guide for Linux, or Windows AMI virtualization types in the Amazon EC2 User Guide for Windows.
Architecture — The CPU architecture between the recommended instance type and the current
instance is different. For example, the recommended instance type might use an Arm CPU architecture and the
current instance type might use a different one, such as x86. Before migrating, you should consider recompiling
the software on your instance for the new architecture. Alternatively, you might switch to an Amazon Machine
Image (AMI) that supports the new architecture. For more information about the CPU architecture for each instance
type, see Amazon EC2 Instance Types.
Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
This method will never return null. If you would like to know whether the service returned this field (so that
you can differentiate between null and empty), you can use the hasPlatformDifferences() method.
Platform differences include:
Hypervisor — The hypervisor of the recommended instance type is different than that
of the current instance. For example, the recommended instance type uses a Nitro hypervisor and the
current instance uses a Xen hypervisor. The differences that you should consider between these
hypervisors are covered in the Nitro
Hypervisor section of the Amazon EC2 frequently asked questions. For more information, see Instances built on the Nitro System in the Amazon EC2 User Guide for Linux, or Instances built on the Nitro System in the Amazon EC2 User Guide for Windows.
NetworkInterface — The network interface of the recommended instance type is
different than that of the current instance. For example, the recommended instance type supports enhanced
networking and the current instance might not. To enable enhanced networking for the recommended instance
type, you must install the Elastic Network Adapter (ENA) driver or the Intel 82599 Virtual Function
driver. For more information, see Networking and storage features and Enhanced networking
on Linux in the Amazon EC2 User Guide for Linux, or Networking and storage features and Enhanced
networking on Windows in the Amazon EC2 User Guide for Windows.
StorageInterface — The storage interface of the recommended instance type is
different than that of the current instance. For example, the recommended instance type uses an NVMe
storage interface and the current instance does not. To access NVMe volumes for the recommended instance
type, you will need to install or upgrade the NVMe driver. For more information, see Networking and storage features and Amazon EBS and NVMe on
Linux instances in the Amazon EC2 User Guide for Linux, or Networking and storage features and Amazon EBS and NVMe
on Windows instances in the Amazon EC2 User Guide for Windows.
InstanceStoreAvailability — The recommended instance type does not support instance
store volumes and the current instance does. Before migrating, you might need to back up the data on your
instance store volumes if you want to preserve them. For more information, see How do I back
up an instance store volume on my Amazon EC2 instance to Amazon EBS? in the Amazon Web Services
Premium Support Knowledge Base. For more information, see Networking and storage features and Amazon EC2 instance
store in the Amazon EC2 User Guide for Linux, or see Networking and storage features and Amazon EC2 instance
store in the Amazon EC2 User Guide for Windows.
VirtualizationType — The recommended instance type uses the hardware virtual
machine (HVM) virtualization type and the current instance uses the paravirtual (PV) virtualization type.
For more information about the differences between these virtualization types, see Linux AMI
virtualization types in the Amazon EC2 User Guide for Linux, or Windows AMI virtualization types in the Amazon EC2 User Guide for Windows.
Architecture — The CPU architecture between the recommended instance type and the
current instance is different. For example, the recommended instance type might use an Arm CPU
architecture and the current instance type might use a different one, such as x86. Before migrating, you
should consider recompiling the software on your instance for the new architecture. Alternatively, you
might switch to an Amazon Machine Image (AMI) that supports the new architecture. For more information
about the CPU architecture for each instance type, see Amazon EC2 Instance Types.
public final boolean hasPlatformDifferences()
isEmpty() method on the property).
This is useful because the SDK will never return a null collection or map, but you may need to differentiate
between the service returning nothing (or null) and the service returning an empty collection or map. For
requests, this returns true if a value for the property was specified in the request builder, and false if a
value was not specified.public final List<String> platformDifferencesAsStrings()
Describes the configuration differences between the current instance and the recommended instance type. You should consider the configuration differences before migrating your workloads from the current instance to the recommended instance type. The Change the instance type guide for Linux and Change the instance type guide for Windows provide general guidance for getting started with an instance migration.
Platform differences include:
Hypervisor — The hypervisor of the recommended instance type is different than that of the
current instance. For example, the recommended instance type uses a Nitro hypervisor and the current instance
uses a Xen hypervisor. The differences that you should consider between these hypervisors are covered in the Nitro Hypervisor section of the Amazon EC2 frequently
asked questions. For more information, see Instances
built on the Nitro System in the Amazon EC2 User Guide for Linux, or Instances
built on the Nitro System in the Amazon EC2 User Guide for Windows.
NetworkInterface — The network interface of the recommended instance type is different than
that of the current instance. For example, the recommended instance type supports enhanced networking and the
current instance might not. To enable enhanced networking for the recommended instance type, you must install the
Elastic Network Adapter (ENA) driver or the Intel 82599 Virtual Function driver. For more information, see
Networking and storage features and Enhanced networking on
Linux in the Amazon EC2 User Guide for Linux, or Networking and storage features and Enhanced networking on
Windows in the Amazon EC2 User Guide for Windows.
StorageInterface — The storage interface of the recommended instance type is different than
that of the current instance. For example, the recommended instance type uses an NVMe storage interface and the
current instance does not. To access NVMe volumes for the recommended instance type, you will need to install or
upgrade the NVMe driver. For more information, see Networking and storage features and Amazon EBS and NVMe on Linux
instances in the Amazon EC2 User Guide for Linux, or Networking and storage features and Amazon EBS and NVMe on
Windows instances in the Amazon EC2 User Guide for Windows.
InstanceStoreAvailability — The recommended instance type does not support instance store
volumes and the current instance does. Before migrating, you might need to back up the data on your instance
store volumes if you want to preserve them. For more information, see How do I back up an
instance store volume on my Amazon EC2 instance to Amazon EBS? in the Amazon Web Services Premium Support
Knowledge Base. For more information, see Networking and storage features and Amazon EC2 instance store in
the Amazon EC2 User Guide for Linux, or see Networking and storage features and Amazon EC2 instance store
in the Amazon EC2 User Guide for Windows.
VirtualizationType — The recommended instance type uses the hardware virtual machine (HVM)
virtualization type and the current instance uses the paravirtual (PV) virtualization type. For more information
about the differences between these virtualization types, see Linux AMI virtualization
types in the Amazon EC2 User Guide for Linux, or Windows AMI virtualization types in the Amazon EC2 User Guide for Windows.
Architecture — The CPU architecture between the recommended instance type and the current
instance is different. For example, the recommended instance type might use an Arm CPU architecture and the
current instance type might use a different one, such as x86. Before migrating, you should consider recompiling
the software on your instance for the new architecture. Alternatively, you might switch to an Amazon Machine
Image (AMI) that supports the new architecture. For more information about the CPU architecture for each instance
type, see Amazon EC2 Instance Types.
Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
This method will never return null. If you would like to know whether the service returned this field (so that
you can differentiate between null and empty), you can use the hasPlatformDifferences() method.
Platform differences include:
Hypervisor — The hypervisor of the recommended instance type is different than that
of the current instance. For example, the recommended instance type uses a Nitro hypervisor and the
current instance uses a Xen hypervisor. The differences that you should consider between these
hypervisors are covered in the Nitro
Hypervisor section of the Amazon EC2 frequently asked questions. For more information, see Instances built on the Nitro System in the Amazon EC2 User Guide for Linux, or Instances built on the Nitro System in the Amazon EC2 User Guide for Windows.
NetworkInterface — The network interface of the recommended instance type is
different than that of the current instance. For example, the recommended instance type supports enhanced
networking and the current instance might not. To enable enhanced networking for the recommended instance
type, you must install the Elastic Network Adapter (ENA) driver or the Intel 82599 Virtual Function
driver. For more information, see Networking and storage features and Enhanced networking
on Linux in the Amazon EC2 User Guide for Linux, or Networking and storage features and Enhanced
networking on Windows in the Amazon EC2 User Guide for Windows.
StorageInterface — The storage interface of the recommended instance type is
different than that of the current instance. For example, the recommended instance type uses an NVMe
storage interface and the current instance does not. To access NVMe volumes for the recommended instance
type, you will need to install or upgrade the NVMe driver. For more information, see Networking and storage features and Amazon EBS and NVMe on
Linux instances in the Amazon EC2 User Guide for Linux, or Networking and storage features and Amazon EBS and NVMe
on Windows instances in the Amazon EC2 User Guide for Windows.
InstanceStoreAvailability — The recommended instance type does not support instance
store volumes and the current instance does. Before migrating, you might need to back up the data on your
instance store volumes if you want to preserve them. For more information, see How do I back
up an instance store volume on my Amazon EC2 instance to Amazon EBS? in the Amazon Web Services
Premium Support Knowledge Base. For more information, see Networking and storage features and Amazon EC2 instance
store in the Amazon EC2 User Guide for Linux, or see Networking and storage features and Amazon EC2 instance
store in the Amazon EC2 User Guide for Windows.
VirtualizationType — The recommended instance type uses the hardware virtual
machine (HVM) virtualization type and the current instance uses the paravirtual (PV) virtualization type.
For more information about the differences between these virtualization types, see Linux AMI
virtualization types in the Amazon EC2 User Guide for Linux, or Windows AMI virtualization types in the Amazon EC2 User Guide for Windows.
Architecture — The CPU architecture between the recommended instance type and the
current instance is different. For example, the recommended instance type might use an Arm CPU
architecture and the current instance type might use a different one, such as x86. Before migrating, you
should consider recompiling the software on your instance for the new architecture. Alternatively, you
might switch to an Amazon Machine Image (AMI) that supports the new architecture. For more information
about the CPU architecture for each instance type, see Amazon EC2 Instance Types.
public final Double performanceRisk()
The performance risk of the instance recommendation option.
Performance risk indicates the likelihood of the recommended instance type not meeting the resource needs of your workload. Compute Optimizer calculates an individual performance risk score for each specification of the recommended instance, including CPU, memory, EBS throughput, EBS IOPS, disk throughput, disk IOPS, network throughput, and network PPS. The performance risk of the recommended instance is calculated as the maximum performance risk score across the analyzed resource specifications.
The value ranges from 0 - 4, with 0 meaning that the recommended resource
is predicted to always provide enough hardware capability. The higher the performance risk is, the more likely
you should validate whether the recommendation will meet the performance requirements of your workload before
migrating your resource.
Performance risk indicates the likelihood of the recommended instance type not meeting the resource needs of your workload. Compute Optimizer calculates an individual performance risk score for each specification of the recommended instance, including CPU, memory, EBS throughput, EBS IOPS, disk throughput, disk IOPS, network throughput, and network PPS. The performance risk of the recommended instance is calculated as the maximum performance risk score across the analyzed resource specifications.
The value ranges from 0 - 4, with 0 meaning that the recommended
resource is predicted to always provide enough hardware capability. The higher the performance risk is,
the more likely you should validate whether the recommendation will meet the performance requirements of
your workload before migrating your resource.
public final Integer rank()
The rank of the instance recommendation option.
The top recommendation option is ranked as 1.
The top recommendation option is ranked as 1.
public final SavingsOpportunity savingsOpportunity()
An object that describes the savings opportunity for the instance recommendation option. Savings opportunity includes the estimated monthly savings amount and percentage.
public final MigrationEffort migrationEffort()
The level of effort required to migrate from the current instance type to the recommended instance type.
For example, the migration effort is Low if Amazon EMR is the inferred workload type and an Amazon
Web Services Graviton instance type is recommended. The migration effort is Medium if a workload
type couldn't be inferred but an Amazon Web Services Graviton instance type is recommended. The migration effort
is VeryLow if both the current and recommended instance types are of the same CPU architecture.
If the service returns an enum value that is not available in the current SDK version, migrationEffort
will return MigrationEffort.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available
from migrationEffortAsString().
For example, the migration effort is Low if Amazon EMR is the inferred workload type and an
Amazon Web Services Graviton instance type is recommended. The migration effort is Medium if
a workload type couldn't be inferred but an Amazon Web Services Graviton instance type is recommended.
The migration effort is VeryLow if both the current and recommended instance types are of
the same CPU architecture.
MigrationEffortpublic final String migrationEffortAsString()
The level of effort required to migrate from the current instance type to the recommended instance type.
For example, the migration effort is Low if Amazon EMR is the inferred workload type and an Amazon
Web Services Graviton instance type is recommended. The migration effort is Medium if a workload
type couldn't be inferred but an Amazon Web Services Graviton instance type is recommended. The migration effort
is VeryLow if both the current and recommended instance types are of the same CPU architecture.
If the service returns an enum value that is not available in the current SDK version, migrationEffort
will return MigrationEffort.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available
from migrationEffortAsString().
For example, the migration effort is Low if Amazon EMR is the inferred workload type and an
Amazon Web Services Graviton instance type is recommended. The migration effort is Medium if
a workload type couldn't be inferred but an Amazon Web Services Graviton instance type is recommended.
The migration effort is VeryLow if both the current and recommended instance types are of
the same CPU architecture.
MigrationEffortpublic InstanceRecommendationOption.Builder toBuilder()
toBuilder in interface ToCopyableBuilder<InstanceRecommendationOption.Builder,InstanceRecommendationOption>public static InstanceRecommendationOption.Builder builder()
public static Class<? extends InstanceRecommendationOption.Builder> serializableBuilderClass()
public final boolean equalsBySdkFields(Object obj)
equalsBySdkFields in interface SdkPojopublic final String toString()
Copyright © 2023. All rights reserved.