Class InstanceGroup
- All Implemented Interfaces:
Serializable
,SdkPojo
,ToCopyableBuilder<InstanceGroup.Builder,
InstanceGroup>
This entity represents an instance group, which is a group of instances that have common purpose. For example, CORE instance group is used for HDFS.
- See Also:
-
Nested Class Summary
Nested Classes -
Method Summary
Modifier and TypeMethodDescriptionAn automatic scaling policy for a core instance group or task instance group in an Amazon EMR cluster.final String
bidPrice()
If specified, indicates that the instance group uses Spot Instances.static InstanceGroup.Builder
builder()
final List
<Configuration> final Long
The version number of the requested configuration specification for this instance group.final String
The custom AMI ID to use for the provisioned instance group.final List
<EbsBlockDevice> The EBS block devices that are mapped to this instance group.final Boolean
If the instance group is EBS-optimized.final boolean
final boolean
equalsBySdkFields
(Object obj) Indicates whether some other object is "equal to" this one by SDK fields.final <T> Optional
<T> getValueForField
(String fieldName, Class<T> clazz) final boolean
For responses, this returns true if the service returned a value for the Configurations property.final boolean
For responses, this returns true if the service returned a value for the EbsBlockDevices property.final int
hashCode()
final boolean
For responses, this returns true if the service returned a value for the LastSuccessfullyAppliedConfigurations property.final String
id()
The identifier of the instance group.final InstanceGroupType
The type of the instance group.final String
The type of the instance group.final String
The Amazon EC2 instance type for all instances in the instance group.final List
<Configuration> A list of configurations that were successfully applied for an instance group last time.final Long
The version number of a configuration specification that was successfully applied for an instance group last time.final MarketType
market()
The marketplace to provision instances for this group.final String
The marketplace to provision instances for this group.final String
name()
The name of the instance group.final Integer
The target number of instances for the instance group.final Integer
The number of instances currently running in this instance group.static Class
<? extends InstanceGroup.Builder> final ShrinkPolicy
Policy for customizing shrink operations.final InstanceGroupStatus
status()
The current status of the instance group.Take this object and create a builder that contains all of the current property values of this object.final String
toString()
Returns a string representation of this object.Methods inherited from interface software.amazon.awssdk.utils.builder.ToCopyableBuilder
copy
-
Method Details
-
id
The identifier of the instance group.
- Returns:
- The identifier of the instance group.
-
name
The name of the instance group.
- Returns:
- The name of the instance group.
-
market
The marketplace to provision instances for this group. Valid values are ON_DEMAND or SPOT.
If the service returns an enum value that is not available in the current SDK version,
market
will returnMarketType.UNKNOWN_TO_SDK_VERSION
. The raw value returned by the service is available frommarketAsString()
.- Returns:
- The marketplace to provision instances for this group. Valid values are ON_DEMAND or SPOT.
- See Also:
-
marketAsString
The marketplace to provision instances for this group. Valid values are ON_DEMAND or SPOT.
If the service returns an enum value that is not available in the current SDK version,
market
will returnMarketType.UNKNOWN_TO_SDK_VERSION
. The raw value returned by the service is available frommarketAsString()
.- Returns:
- The marketplace to provision instances for this group. Valid values are ON_DEMAND or SPOT.
- See Also:
-
instanceGroupType
The type of the instance group. Valid values are MASTER, CORE or TASK.
If the service returns an enum value that is not available in the current SDK version,
instanceGroupType
will returnInstanceGroupType.UNKNOWN_TO_SDK_VERSION
. The raw value returned by the service is available frominstanceGroupTypeAsString()
.- Returns:
- The type of the instance group. Valid values are MASTER, CORE or TASK.
- See Also:
-
instanceGroupTypeAsString
The type of the instance group. Valid values are MASTER, CORE or TASK.
If the service returns an enum value that is not available in the current SDK version,
instanceGroupType
will returnInstanceGroupType.UNKNOWN_TO_SDK_VERSION
. The raw value returned by the service is available frominstanceGroupTypeAsString()
.- Returns:
- The type of the instance group. Valid values are MASTER, CORE or TASK.
- See Also:
-
bidPrice
If specified, indicates that the instance group uses Spot Instances. This is the maximum price you are willing to pay for Spot Instances. Specify
OnDemandPrice
to set the amount equal to the On-Demand price, or specify an amount in USD.- Returns:
- If specified, indicates that the instance group uses Spot Instances. This is the maximum price you are
willing to pay for Spot Instances. Specify
OnDemandPrice
to set the amount equal to the On-Demand price, or specify an amount in USD.
-
instanceType
The Amazon EC2 instance type for all instances in the instance group.
- Returns:
- The Amazon EC2 instance type for all instances in the instance group.
-
requestedInstanceCount
The target number of instances for the instance group.
- Returns:
- The target number of instances for the instance group.
-
runningInstanceCount
The number of instances currently running in this instance group.
- Returns:
- The number of instances currently running in this instance group.
-
status
The current status of the instance group.
- Returns:
- The current status of the instance group.
-
hasConfigurations
public final boolean hasConfigurations()For responses, this returns true if the service returned a value for the Configurations property. This DOES NOT check that the value is non-empty (for which, you should check theisEmpty()
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. -
configurations
Amazon EMR releases 4.x or higher.
The list of configurations supplied for an Amazon EMR cluster instance group. You can specify a separate configuration for each instance group (master, core, and task).
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
hasConfigurations()
method.- Returns:
Amazon EMR releases 4.x or higher.
The list of configurations supplied for an Amazon EMR cluster instance group. You can specify a separate configuration for each instance group (master, core, and task).
-
configurationsVersion
The version number of the requested configuration specification for this instance group.
- Returns:
- The version number of the requested configuration specification for this instance group.
-
hasLastSuccessfullyAppliedConfigurations
public final boolean hasLastSuccessfullyAppliedConfigurations()For responses, this returns true if the service returned a value for the LastSuccessfullyAppliedConfigurations property. This DOES NOT check that the value is non-empty (for which, you should check theisEmpty()
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. -
lastSuccessfullyAppliedConfigurations
A list of configurations that were successfully applied for an instance group last time.
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
hasLastSuccessfullyAppliedConfigurations()
method.- Returns:
- A list of configurations that were successfully applied for an instance group last time.
-
lastSuccessfullyAppliedConfigurationsVersion
The version number of a configuration specification that was successfully applied for an instance group last time.
- Returns:
- The version number of a configuration specification that was successfully applied for an instance group last time.
-
hasEbsBlockDevices
public final boolean hasEbsBlockDevices()For responses, this returns true if the service returned a value for the EbsBlockDevices property. This DOES NOT check that the value is non-empty (for which, you should check theisEmpty()
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. -
ebsBlockDevices
The EBS block devices that are mapped to this instance group.
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
hasEbsBlockDevices()
method.- Returns:
- The EBS block devices that are mapped to this instance group.
-
ebsOptimized
If the instance group is EBS-optimized. An Amazon EBS-optimized instance uses an optimized configuration stack and provides additional, dedicated capacity for Amazon EBS I/O.
- Returns:
- If the instance group is EBS-optimized. An Amazon EBS-optimized instance uses an optimized configuration stack and provides additional, dedicated capacity for Amazon EBS I/O.
-
shrinkPolicy
Policy for customizing shrink operations.
- Returns:
- Policy for customizing shrink operations.
-
autoScalingPolicy
An automatic scaling policy for a core instance group or task instance group in an Amazon EMR cluster. The automatic scaling policy defines how an instance group dynamically adds and terminates Amazon EC2 instances in response to the value of a CloudWatch metric. See PutAutoScalingPolicy.
- Returns:
- An automatic scaling policy for a core instance group or task instance group in an Amazon EMR cluster. The automatic scaling policy defines how an instance group dynamically adds and terminates Amazon EC2 instances in response to the value of a CloudWatch metric. See PutAutoScalingPolicy.
-
customAmiId
The custom AMI ID to use for the provisioned instance group.
- Returns:
- The custom AMI ID to use for the provisioned instance group.
-
toBuilder
Description copied from interface:ToCopyableBuilder
Take this object and create a builder that contains all of the current property values of this object.- Specified by:
toBuilder
in interfaceToCopyableBuilder<InstanceGroup.Builder,
InstanceGroup> - Returns:
- a builder for type T
-
builder
-
serializableBuilderClass
-
hashCode
public final int hashCode() -
equals
-
equalsBySdkFields
Description copied from interface:SdkPojo
Indicates whether some other object is "equal to" this one by SDK fields. An SDK field is a modeled, non-inherited field in anSdkPojo
class, and is generated based on a service model.If an
SdkPojo
class does not have any inherited fields,equalsBySdkFields
andequals
are essentially the same.- Specified by:
equalsBySdkFields
in interfaceSdkPojo
- Parameters:
obj
- the object to be compared with- Returns:
- true if the other object equals to this object by sdk fields, false otherwise.
-
toString
Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be redacted from this string using a placeholder value. -
getValueForField
-
sdkFields
-