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

Configuration defining a new instance group.

See Also:

AWS * API Reference

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

Friendly name given to the instance group.

*/ inline const Aws::String& GetName() const{ return m_name; } /** *

Friendly name given to the instance group.

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

Friendly name given to the instance group.

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

Friendly name given to the instance group.

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

Friendly name given to the instance group.

*/ inline void SetName(const char* value) { m_nameHasBeenSet = true; m_name.assign(value); } /** *

Friendly name given to the instance group.

*/ inline InstanceGroupConfig& WithName(const Aws::String& value) { SetName(value); return *this;} /** *

Friendly name given to the instance group.

*/ inline InstanceGroupConfig& WithName(Aws::String&& value) { SetName(std::move(value)); return *this;} /** *

Friendly name given to the instance group.

*/ inline InstanceGroupConfig& WithName(const char* value) { SetName(value); return *this;} /** *

Market type of the Amazon EC2 instances used to create a cluster node.

*/ inline const MarketType& GetMarket() const{ return m_market; } /** *

Market type of the Amazon EC2 instances used to create a cluster node.

*/ inline bool MarketHasBeenSet() const { return m_marketHasBeenSet; } /** *

Market type of the Amazon EC2 instances used to create a cluster node.

*/ inline void SetMarket(const MarketType& value) { m_marketHasBeenSet = true; m_market = value; } /** *

Market type of the Amazon EC2 instances used to create a cluster node.

*/ inline void SetMarket(MarketType&& value) { m_marketHasBeenSet = true; m_market = std::move(value); } /** *

Market type of the Amazon EC2 instances used to create a cluster node.

*/ inline InstanceGroupConfig& WithMarket(const MarketType& value) { SetMarket(value); return *this;} /** *

Market type of the Amazon EC2 instances used to create a cluster node.

*/ inline InstanceGroupConfig& WithMarket(MarketType&& value) { SetMarket(std::move(value)); return *this;} /** *

The role of the instance group in the cluster.

*/ inline const InstanceRoleType& GetInstanceRole() const{ return m_instanceRole; } /** *

The role of the instance group in the cluster.

*/ inline bool InstanceRoleHasBeenSet() const { return m_instanceRoleHasBeenSet; } /** *

The role of the instance group in the cluster.

*/ inline void SetInstanceRole(const InstanceRoleType& value) { m_instanceRoleHasBeenSet = true; m_instanceRole = value; } /** *

The role of the instance group in the cluster.

*/ inline void SetInstanceRole(InstanceRoleType&& value) { m_instanceRoleHasBeenSet = true; m_instanceRole = std::move(value); } /** *

The role of the instance group in the cluster.

*/ inline InstanceGroupConfig& WithInstanceRole(const InstanceRoleType& value) { SetInstanceRole(value); return *this;} /** *

The role of the instance group in the cluster.

*/ inline InstanceGroupConfig& WithInstanceRole(InstanceRoleType&& value) { SetInstanceRole(std::move(value)); return *this;} /** *

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.

*/ inline const Aws::String& GetBidPrice() const{ return m_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.

*/ inline bool BidPriceHasBeenSet() const { return m_bidPriceHasBeenSet; } /** *

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.

*/ inline void SetBidPrice(const Aws::String& value) { m_bidPriceHasBeenSet = true; m_bidPrice = value; } /** *

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.

*/ inline void SetBidPrice(Aws::String&& value) { m_bidPriceHasBeenSet = true; m_bidPrice = std::move(value); } /** *

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.

*/ inline void SetBidPrice(const char* value) { m_bidPriceHasBeenSet = true; m_bidPrice.assign(value); } /** *

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.

*/ inline InstanceGroupConfig& WithBidPrice(const Aws::String& value) { SetBidPrice(value); return *this;} /** *

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.

*/ inline InstanceGroupConfig& WithBidPrice(Aws::String&& value) { SetBidPrice(std::move(value)); return *this;} /** *

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.

*/ inline InstanceGroupConfig& WithBidPrice(const char* value) { SetBidPrice(value); return *this;} /** *

The Amazon EC2 instance type for all instances in the instance group.

*/ inline const Aws::String& GetInstanceType() const{ return m_instanceType; } /** *

The Amazon EC2 instance type for all instances in the instance group.

*/ inline bool InstanceTypeHasBeenSet() const { return m_instanceTypeHasBeenSet; } /** *

The Amazon EC2 instance type for all instances in the instance group.

*/ inline void SetInstanceType(const Aws::String& value) { m_instanceTypeHasBeenSet = true; m_instanceType = value; } /** *

The Amazon EC2 instance type for all instances in the instance group.

*/ inline void SetInstanceType(Aws::String&& value) { m_instanceTypeHasBeenSet = true; m_instanceType = std::move(value); } /** *

The Amazon EC2 instance type for all instances in the instance group.

*/ inline void SetInstanceType(const char* value) { m_instanceTypeHasBeenSet = true; m_instanceType.assign(value); } /** *

The Amazon EC2 instance type for all instances in the instance group.

*/ inline InstanceGroupConfig& WithInstanceType(const Aws::String& value) { SetInstanceType(value); return *this;} /** *

The Amazon EC2 instance type for all instances in the instance group.

*/ inline InstanceGroupConfig& WithInstanceType(Aws::String&& value) { SetInstanceType(std::move(value)); return *this;} /** *

The Amazon EC2 instance type for all instances in the instance group.

*/ inline InstanceGroupConfig& WithInstanceType(const char* value) { SetInstanceType(value); return *this;} /** *

Target number of instances for the instance group.

*/ inline int GetInstanceCount() const{ return m_instanceCount; } /** *

Target number of instances for the instance group.

*/ inline bool InstanceCountHasBeenSet() const { return m_instanceCountHasBeenSet; } /** *

Target number of instances for the instance group.

*/ inline void SetInstanceCount(int value) { m_instanceCountHasBeenSet = true; m_instanceCount = value; } /** *

Target number of instances for the instance group.

*/ inline InstanceGroupConfig& WithInstanceCount(int value) { SetInstanceCount(value); return *this;} /** *

Amazon EMR releases 4.x or later.

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).

*/ inline const Aws::Vector& GetConfigurations() const{ return m_configurations; } /** *

Amazon EMR releases 4.x or later.

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).

*/ inline bool ConfigurationsHasBeenSet() const { return m_configurationsHasBeenSet; } /** *

Amazon EMR releases 4.x or later.

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).

*/ inline void SetConfigurations(const Aws::Vector& value) { m_configurationsHasBeenSet = true; m_configurations = value; } /** *

Amazon EMR releases 4.x or later.

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).

*/ inline void SetConfigurations(Aws::Vector&& value) { m_configurationsHasBeenSet = true; m_configurations = std::move(value); } /** *

Amazon EMR releases 4.x or later.

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).

*/ inline InstanceGroupConfig& WithConfigurations(const Aws::Vector& value) { SetConfigurations(value); return *this;} /** *

Amazon EMR releases 4.x or later.

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).

*/ inline InstanceGroupConfig& WithConfigurations(Aws::Vector&& value) { SetConfigurations(std::move(value)); return *this;} /** *

Amazon EMR releases 4.x or later.

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).

*/ inline InstanceGroupConfig& AddConfigurations(const Configuration& value) { m_configurationsHasBeenSet = true; m_configurations.push_back(value); return *this; } /** *

Amazon EMR releases 4.x or later.

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).

*/ inline InstanceGroupConfig& AddConfigurations(Configuration&& value) { m_configurationsHasBeenSet = true; m_configurations.push_back(std::move(value)); return *this; } /** *

EBS configurations that will be attached to each Amazon EC2 instance in the * instance group.

*/ inline const EbsConfiguration& GetEbsConfiguration() const{ return m_ebsConfiguration; } /** *

EBS configurations that will be attached to each Amazon EC2 instance in the * instance group.

*/ inline bool EbsConfigurationHasBeenSet() const { return m_ebsConfigurationHasBeenSet; } /** *

EBS configurations that will be attached to each Amazon EC2 instance in the * instance group.

*/ inline void SetEbsConfiguration(const EbsConfiguration& value) { m_ebsConfigurationHasBeenSet = true; m_ebsConfiguration = value; } /** *

EBS configurations that will be attached to each Amazon EC2 instance in the * instance group.

*/ inline void SetEbsConfiguration(EbsConfiguration&& value) { m_ebsConfigurationHasBeenSet = true; m_ebsConfiguration = std::move(value); } /** *

EBS configurations that will be attached to each Amazon EC2 instance in the * instance group.

*/ inline InstanceGroupConfig& WithEbsConfiguration(const EbsConfiguration& value) { SetEbsConfiguration(value); return *this;} /** *

EBS configurations that will be attached to each Amazon EC2 instance in the * instance group.

*/ inline InstanceGroupConfig& WithEbsConfiguration(EbsConfiguration&& value) { SetEbsConfiguration(std::move(value)); return *this;} /** *

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.

*/ inline const AutoScalingPolicy& GetAutoScalingPolicy() const{ return m_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.

*/ inline bool AutoScalingPolicyHasBeenSet() const { return m_autoScalingPolicyHasBeenSet; } /** *

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.

*/ inline void SetAutoScalingPolicy(const AutoScalingPolicy& value) { m_autoScalingPolicyHasBeenSet = true; m_autoScalingPolicy = value; } /** *

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.

*/ inline void SetAutoScalingPolicy(AutoScalingPolicy&& value) { m_autoScalingPolicyHasBeenSet = true; m_autoScalingPolicy = std::move(value); } /** *

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.

*/ inline InstanceGroupConfig& WithAutoScalingPolicy(const AutoScalingPolicy& value) { SetAutoScalingPolicy(value); return *this;} /** *

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.

*/ inline InstanceGroupConfig& WithAutoScalingPolicy(AutoScalingPolicy&& value) { SetAutoScalingPolicy(std::move(value)); return *this;} /** *

The custom AMI ID to use for the provisioned instance group.

*/ inline const Aws::String& GetCustomAmiId() const{ return m_customAmiId; } /** *

The custom AMI ID to use for the provisioned instance group.

*/ inline bool CustomAmiIdHasBeenSet() const { return m_customAmiIdHasBeenSet; } /** *

The custom AMI ID to use for the provisioned instance group.

*/ inline void SetCustomAmiId(const Aws::String& value) { m_customAmiIdHasBeenSet = true; m_customAmiId = value; } /** *

The custom AMI ID to use for the provisioned instance group.

*/ inline void SetCustomAmiId(Aws::String&& value) { m_customAmiIdHasBeenSet = true; m_customAmiId = std::move(value); } /** *

The custom AMI ID to use for the provisioned instance group.

*/ inline void SetCustomAmiId(const char* value) { m_customAmiIdHasBeenSet = true; m_customAmiId.assign(value); } /** *

The custom AMI ID to use for the provisioned instance group.

*/ inline InstanceGroupConfig& WithCustomAmiId(const Aws::String& value) { SetCustomAmiId(value); return *this;} /** *

The custom AMI ID to use for the provisioned instance group.

*/ inline InstanceGroupConfig& WithCustomAmiId(Aws::String&& value) { SetCustomAmiId(std::move(value)); return *this;} /** *

The custom AMI ID to use for the provisioned instance group.

*/ inline InstanceGroupConfig& WithCustomAmiId(const char* value) { SetCustomAmiId(value); return *this;} private: Aws::String m_name; bool m_nameHasBeenSet = false; MarketType m_market; bool m_marketHasBeenSet = false; InstanceRoleType m_instanceRole; bool m_instanceRoleHasBeenSet = false; Aws::String m_bidPrice; bool m_bidPriceHasBeenSet = false; Aws::String m_instanceType; bool m_instanceTypeHasBeenSet = false; int m_instanceCount; bool m_instanceCountHasBeenSet = false; Aws::Vector m_configurations; bool m_configurationsHasBeenSet = false; EbsConfiguration m_ebsConfiguration; bool m_ebsConfigurationHasBeenSet = false; AutoScalingPolicy m_autoScalingPolicy; bool m_autoScalingPolicyHasBeenSet = false; Aws::String m_customAmiId; bool m_customAmiIdHasBeenSet = false; }; } // namespace Model } // namespace EMR } // namespace Aws