@Generated(value="com.amazonaws:aws-java-sdk-code-generator") public class SpotProvisioningSpecification extends Object implements Serializable, Cloneable, StructuredPojo
The launch specification for Spot Instances in the instance fleet, which determines the defined duration, provisioning timeout behavior, and allocation strategy.
The instance fleet configuration is available only in Amazon EMR versions 4.8.0 and later, excluding 5.0.x versions. Spot Instance allocation strategy is available in Amazon EMR version 5.12.1 and later.
| Constructor and Description | 
|---|
| SpotProvisioningSpecification() | 
| Modifier and Type | Method and Description | 
|---|---|
| SpotProvisioningSpecification | clone() | 
| boolean | equals(Object obj) | 
| String | getAllocationStrategy()
 Specifies the strategy to use in launching Spot Instance fleets. | 
| Integer | getBlockDurationMinutes()
 The defined duration for Spot Instances (also known as Spot blocks) in minutes. | 
| String | getTimeoutAction()
 The action to take when  TargetSpotCapacityhas not been fulfilled when theTimeoutDurationMinuteshas expired; that is, when all Spot Instances could not be provisioned within
 the Spot provisioning timeout. | 
| Integer | getTimeoutDurationMinutes()
 The spot provisioning timeout period in minutes. | 
| int | hashCode() | 
| void | marshall(ProtocolMarshaller protocolMarshaller)Marshalls this structured data using the given  ProtocolMarshaller. | 
| void | setAllocationStrategy(SpotProvisioningAllocationStrategy allocationStrategy)
 Specifies the strategy to use in launching Spot Instance fleets. | 
| void | setAllocationStrategy(String allocationStrategy)
 Specifies the strategy to use in launching Spot Instance fleets. | 
| void | setBlockDurationMinutes(Integer blockDurationMinutes)
 The defined duration for Spot Instances (also known as Spot blocks) in minutes. | 
| void | setTimeoutAction(SpotProvisioningTimeoutAction timeoutAction)
 The action to take when  TargetSpotCapacityhas not been fulfilled when theTimeoutDurationMinuteshas expired; that is, when all Spot Instances could not be provisioned within
 the Spot provisioning timeout. | 
| void | setTimeoutAction(String timeoutAction)
 The action to take when  TargetSpotCapacityhas not been fulfilled when theTimeoutDurationMinuteshas expired; that is, when all Spot Instances could not be provisioned within
 the Spot provisioning timeout. | 
| void | setTimeoutDurationMinutes(Integer timeoutDurationMinutes)
 The spot provisioning timeout period in minutes. | 
| String | toString()Returns a string representation of this object. | 
| SpotProvisioningSpecification | withAllocationStrategy(SpotProvisioningAllocationStrategy allocationStrategy)
 Specifies the strategy to use in launching Spot Instance fleets. | 
| SpotProvisioningSpecification | withAllocationStrategy(String allocationStrategy)
 Specifies the strategy to use in launching Spot Instance fleets. | 
| SpotProvisioningSpecification | withBlockDurationMinutes(Integer blockDurationMinutes)
 The defined duration for Spot Instances (also known as Spot blocks) in minutes. | 
| SpotProvisioningSpecification | withTimeoutAction(SpotProvisioningTimeoutAction timeoutAction)
 The action to take when  TargetSpotCapacityhas not been fulfilled when theTimeoutDurationMinuteshas expired; that is, when all Spot Instances could not be provisioned within
 the Spot provisioning timeout. | 
| SpotProvisioningSpecification | withTimeoutAction(String timeoutAction)
 The action to take when  TargetSpotCapacityhas not been fulfilled when theTimeoutDurationMinuteshas expired; that is, when all Spot Instances could not be provisioned within
 the Spot provisioning timeout. | 
| SpotProvisioningSpecification | withTimeoutDurationMinutes(Integer timeoutDurationMinutes)
 The spot provisioning timeout period in minutes. | 
public void setTimeoutDurationMinutes(Integer timeoutDurationMinutes)
 The spot provisioning timeout period in minutes. If Spot Instances are not provisioned within this time period,
 the TimeOutAction is taken. Minimum value is 5 and maximum value is 1440. The timeout applies only
 during initial provisioning, when the cluster is first created.
 
timeoutDurationMinutes - The spot provisioning timeout period in minutes. If Spot Instances are not provisioned within this time
        period, the TimeOutAction is taken. Minimum value is 5 and maximum value is 1440. The timeout
        applies only during initial provisioning, when the cluster is first created.public Integer getTimeoutDurationMinutes()
 The spot provisioning timeout period in minutes. If Spot Instances are not provisioned within this time period,
 the TimeOutAction is taken. Minimum value is 5 and maximum value is 1440. The timeout applies only
 during initial provisioning, when the cluster is first created.
 
TimeOutAction is taken. Minimum value is 5 and maximum value is 1440. The
         timeout applies only during initial provisioning, when the cluster is first created.public SpotProvisioningSpecification withTimeoutDurationMinutes(Integer timeoutDurationMinutes)
 The spot provisioning timeout period in minutes. If Spot Instances are not provisioned within this time period,
 the TimeOutAction is taken. Minimum value is 5 and maximum value is 1440. The timeout applies only
 during initial provisioning, when the cluster is first created.
 
timeoutDurationMinutes - The spot provisioning timeout period in minutes. If Spot Instances are not provisioned within this time
        period, the TimeOutAction is taken. Minimum value is 5 and maximum value is 1440. The timeout
        applies only during initial provisioning, when the cluster is first created.public void setTimeoutAction(String timeoutAction)
 The action to take when TargetSpotCapacity has not been fulfilled when the
 TimeoutDurationMinutes has expired; that is, when all Spot Instances could not be provisioned within
 the Spot provisioning timeout. Valid values are TERMINATE_CLUSTER and
 SWITCH_TO_ON_DEMAND. SWITCH_TO_ON_DEMAND specifies that if no Spot Instances are available,
 On-Demand Instances should be provisioned to fulfill any remaining Spot capacity.
 
timeoutAction - The action to take when TargetSpotCapacity has not been fulfilled when the
        TimeoutDurationMinutes has expired; that is, when all Spot Instances could not be provisioned
        within the Spot provisioning timeout. Valid values are TERMINATE_CLUSTER and
        SWITCH_TO_ON_DEMAND. SWITCH_TO_ON_DEMAND specifies that if no Spot Instances are available,
        On-Demand Instances should be provisioned to fulfill any remaining Spot capacity.SpotProvisioningTimeoutActionpublic String getTimeoutAction()
 The action to take when TargetSpotCapacity has not been fulfilled when the
 TimeoutDurationMinutes has expired; that is, when all Spot Instances could not be provisioned within
 the Spot provisioning timeout. Valid values are TERMINATE_CLUSTER and
 SWITCH_TO_ON_DEMAND. SWITCH_TO_ON_DEMAND specifies that if no Spot Instances are available,
 On-Demand Instances should be provisioned to fulfill any remaining Spot capacity.
 
TargetSpotCapacity has not been fulfilled when the
         TimeoutDurationMinutes has expired; that is, when all Spot Instances could not be
         provisioned within the Spot provisioning timeout. Valid values are TERMINATE_CLUSTER and
         SWITCH_TO_ON_DEMAND. SWITCH_TO_ON_DEMAND specifies that if no Spot Instances are available,
         On-Demand Instances should be provisioned to fulfill any remaining Spot capacity.SpotProvisioningTimeoutActionpublic SpotProvisioningSpecification withTimeoutAction(String timeoutAction)
 The action to take when TargetSpotCapacity has not been fulfilled when the
 TimeoutDurationMinutes has expired; that is, when all Spot Instances could not be provisioned within
 the Spot provisioning timeout. Valid values are TERMINATE_CLUSTER and
 SWITCH_TO_ON_DEMAND. SWITCH_TO_ON_DEMAND specifies that if no Spot Instances are available,
 On-Demand Instances should be provisioned to fulfill any remaining Spot capacity.
 
timeoutAction - The action to take when TargetSpotCapacity has not been fulfilled when the
        TimeoutDurationMinutes has expired; that is, when all Spot Instances could not be provisioned
        within the Spot provisioning timeout. Valid values are TERMINATE_CLUSTER and
        SWITCH_TO_ON_DEMAND. SWITCH_TO_ON_DEMAND specifies that if no Spot Instances are available,
        On-Demand Instances should be provisioned to fulfill any remaining Spot capacity.SpotProvisioningTimeoutActionpublic void setTimeoutAction(SpotProvisioningTimeoutAction timeoutAction)
 The action to take when TargetSpotCapacity has not been fulfilled when the
 TimeoutDurationMinutes has expired; that is, when all Spot Instances could not be provisioned within
 the Spot provisioning timeout. Valid values are TERMINATE_CLUSTER and
 SWITCH_TO_ON_DEMAND. SWITCH_TO_ON_DEMAND specifies that if no Spot Instances are available,
 On-Demand Instances should be provisioned to fulfill any remaining Spot capacity.
 
timeoutAction - The action to take when TargetSpotCapacity has not been fulfilled when the
        TimeoutDurationMinutes has expired; that is, when all Spot Instances could not be provisioned
        within the Spot provisioning timeout. Valid values are TERMINATE_CLUSTER and
        SWITCH_TO_ON_DEMAND. SWITCH_TO_ON_DEMAND specifies that if no Spot Instances are available,
        On-Demand Instances should be provisioned to fulfill any remaining Spot capacity.SpotProvisioningTimeoutActionpublic SpotProvisioningSpecification withTimeoutAction(SpotProvisioningTimeoutAction timeoutAction)
 The action to take when TargetSpotCapacity has not been fulfilled when the
 TimeoutDurationMinutes has expired; that is, when all Spot Instances could not be provisioned within
 the Spot provisioning timeout. Valid values are TERMINATE_CLUSTER and
 SWITCH_TO_ON_DEMAND. SWITCH_TO_ON_DEMAND specifies that if no Spot Instances are available,
 On-Demand Instances should be provisioned to fulfill any remaining Spot capacity.
 
timeoutAction - The action to take when TargetSpotCapacity has not been fulfilled when the
        TimeoutDurationMinutes has expired; that is, when all Spot Instances could not be provisioned
        within the Spot provisioning timeout. Valid values are TERMINATE_CLUSTER and
        SWITCH_TO_ON_DEMAND. SWITCH_TO_ON_DEMAND specifies that if no Spot Instances are available,
        On-Demand Instances should be provisioned to fulfill any remaining Spot capacity.SpotProvisioningTimeoutActionpublic void setBlockDurationMinutes(Integer blockDurationMinutes)
The defined duration for Spot Instances (also known as Spot blocks) in minutes. When specified, the Spot Instance does not terminate before the defined duration expires, and defined duration pricing for Spot Instances applies. Valid values are 60, 120, 180, 240, 300, or 360. The duration period starts as soon as a Spot Instance receives its instance ID. At the end of the duration, Amazon EC2 marks the Spot Instance for termination and provides a Spot Instance termination notice, which gives the instance a two-minute warning before it terminates.
blockDurationMinutes - The defined duration for Spot Instances (also known as Spot blocks) in minutes. When specified, the Spot
        Instance does not terminate before the defined duration expires, and defined duration pricing for Spot
        Instances applies. Valid values are 60, 120, 180, 240, 300, or 360. The duration period starts as soon as
        a Spot Instance receives its instance ID. At the end of the duration, Amazon EC2 marks the Spot Instance
        for termination and provides a Spot Instance termination notice, which gives the instance a two-minute
        warning before it terminates.public Integer getBlockDurationMinutes()
The defined duration for Spot Instances (also known as Spot blocks) in minutes. When specified, the Spot Instance does not terminate before the defined duration expires, and defined duration pricing for Spot Instances applies. Valid values are 60, 120, 180, 240, 300, or 360. The duration period starts as soon as a Spot Instance receives its instance ID. At the end of the duration, Amazon EC2 marks the Spot Instance for termination and provides a Spot Instance termination notice, which gives the instance a two-minute warning before it terminates.
public SpotProvisioningSpecification withBlockDurationMinutes(Integer blockDurationMinutes)
The defined duration for Spot Instances (also known as Spot blocks) in minutes. When specified, the Spot Instance does not terminate before the defined duration expires, and defined duration pricing for Spot Instances applies. Valid values are 60, 120, 180, 240, 300, or 360. The duration period starts as soon as a Spot Instance receives its instance ID. At the end of the duration, Amazon EC2 marks the Spot Instance for termination and provides a Spot Instance termination notice, which gives the instance a two-minute warning before it terminates.
blockDurationMinutes - The defined duration for Spot Instances (also known as Spot blocks) in minutes. When specified, the Spot
        Instance does not terminate before the defined duration expires, and defined duration pricing for Spot
        Instances applies. Valid values are 60, 120, 180, 240, 300, or 360. The duration period starts as soon as
        a Spot Instance receives its instance ID. At the end of the duration, Amazon EC2 marks the Spot Instance
        for termination and provides a Spot Instance termination notice, which gives the instance a two-minute
        warning before it terminates.public void setAllocationStrategy(String allocationStrategy)
Specifies the strategy to use in launching Spot Instance fleets. Currently, the only option is capacity-optimized (the default), which launches instances from Spot Instance pools with optimal capacity for the number of instances that are launching.
allocationStrategy - Specifies the strategy to use in launching Spot Instance fleets. Currently, the only option is
        capacity-optimized (the default), which launches instances from Spot Instance pools with optimal capacity
        for the number of instances that are launching.SpotProvisioningAllocationStrategypublic String getAllocationStrategy()
Specifies the strategy to use in launching Spot Instance fleets. Currently, the only option is capacity-optimized (the default), which launches instances from Spot Instance pools with optimal capacity for the number of instances that are launching.
SpotProvisioningAllocationStrategypublic SpotProvisioningSpecification withAllocationStrategy(String allocationStrategy)
Specifies the strategy to use in launching Spot Instance fleets. Currently, the only option is capacity-optimized (the default), which launches instances from Spot Instance pools with optimal capacity for the number of instances that are launching.
allocationStrategy - Specifies the strategy to use in launching Spot Instance fleets. Currently, the only option is
        capacity-optimized (the default), which launches instances from Spot Instance pools with optimal capacity
        for the number of instances that are launching.SpotProvisioningAllocationStrategypublic void setAllocationStrategy(SpotProvisioningAllocationStrategy allocationStrategy)
Specifies the strategy to use in launching Spot Instance fleets. Currently, the only option is capacity-optimized (the default), which launches instances from Spot Instance pools with optimal capacity for the number of instances that are launching.
allocationStrategy - Specifies the strategy to use in launching Spot Instance fleets. Currently, the only option is
        capacity-optimized (the default), which launches instances from Spot Instance pools with optimal capacity
        for the number of instances that are launching.SpotProvisioningAllocationStrategypublic SpotProvisioningSpecification withAllocationStrategy(SpotProvisioningAllocationStrategy allocationStrategy)
Specifies the strategy to use in launching Spot Instance fleets. Currently, the only option is capacity-optimized (the default), which launches instances from Spot Instance pools with optimal capacity for the number of instances that are launching.
allocationStrategy - Specifies the strategy to use in launching Spot Instance fleets. Currently, the only option is
        capacity-optimized (the default), which launches instances from Spot Instance pools with optimal capacity
        for the number of instances that are launching.SpotProvisioningAllocationStrategypublic String toString()
toString in class ObjectObject.toString()public SpotProvisioningSpecification clone()
public void marshall(ProtocolMarshaller protocolMarshaller)
StructuredPojoProtocolMarshaller.marshall in interface StructuredPojoprotocolMarshaller - Implementation of ProtocolMarshaller used to marshall this object's data.