Alibaba Cloud v3.75.0 published on Friday, Mar 7, 2025 by Pulumi
alicloud.emr.getInstanceTypes
Explore with Pulumi AI
The alicloud.emr.getInstanceTypes data source provides a collection of ecs
instance types available in Alibaba Cloud account when create a emr cluster.
NOTE: Available in 1.59.0+
Example Usage
import * as pulumi from "@pulumi/pulumi";
import * as alicloud from "@pulumi/alicloud";
const _default = alicloud.emr.getInstanceTypes({
    destinationResource: "InstanceType",
    instanceChargeType: "PostPaid",
    supportLocalStorage: false,
    clusterType: "HADOOP",
    instanceType: "ecs.g5.2xlarge",
    supportNodeTypes: [
        "MASTER",
        "CORE",
    ],
});
export const firstInstanceType = _default.then(_default => _default.types?.[0]?.id);
import pulumi
import pulumi_alicloud as alicloud
default = alicloud.emr.get_instance_types(destination_resource="InstanceType",
    instance_charge_type="PostPaid",
    support_local_storage=False,
    cluster_type="HADOOP",
    instance_type="ecs.g5.2xlarge",
    support_node_types=[
        "MASTER",
        "CORE",
    ])
pulumi.export("firstInstanceType", default.types[0].id)
package main
import (
	"github.com/pulumi/pulumi-alicloud/sdk/v3/go/alicloud/emr"
	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
	pulumi.Run(func(ctx *pulumi.Context) error {
		_default, err := emr.GetInstanceTypes(ctx, &emr.GetInstanceTypesArgs{
			DestinationResource: "InstanceType",
			InstanceChargeType:  "PostPaid",
			SupportLocalStorage: pulumi.BoolRef(false),
			ClusterType:         "HADOOP",
			InstanceType:        pulumi.StringRef("ecs.g5.2xlarge"),
			SupportNodeTypes: []string{
				"MASTER",
				"CORE",
			},
		}, nil)
		if err != nil {
			return err
		}
		ctx.Export("firstInstanceType", _default.Types[0].Id)
		return nil
	})
}
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using AliCloud = Pulumi.AliCloud;
return await Deployment.RunAsync(() => 
{
    var @default = AliCloud.Emr.GetInstanceTypes.Invoke(new()
    {
        DestinationResource = "InstanceType",
        InstanceChargeType = "PostPaid",
        SupportLocalStorage = false,
        ClusterType = "HADOOP",
        InstanceType = "ecs.g5.2xlarge",
        SupportNodeTypes = new[]
        {
            "MASTER",
            "CORE",
        },
    });
    return new Dictionary<string, object?>
    {
        ["firstInstanceType"] = @default.Apply(@default => @default.Apply(getInstanceTypesResult => getInstanceTypesResult.Types[0]?.Id)),
    };
});
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.alicloud.emr.EmrFunctions;
import com.pulumi.alicloud.emr.inputs.GetInstanceTypesArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
    public static void main(String[] args) {
        Pulumi.run(App::stack);
    }
    public static void stack(Context ctx) {
        final var default = EmrFunctions.getInstanceTypes(GetInstanceTypesArgs.builder()
            .destinationResource("InstanceType")
            .instanceChargeType("PostPaid")
            .supportLocalStorage(false)
            .clusterType("HADOOP")
            .instanceType("ecs.g5.2xlarge")
            .supportNodeTypes(            
                "MASTER",
                "CORE")
            .build());
        ctx.export("firstInstanceType", default_.types()[0].id());
    }
}
variables:
  default:
    fn::invoke:
      function: alicloud:emr:getInstanceTypes
      arguments:
        destinationResource: InstanceType
        instanceChargeType: PostPaid
        supportLocalStorage: false
        clusterType: HADOOP
        instanceType: ecs.g5.2xlarge
        supportNodeTypes:
          - MASTER
          - CORE
outputs:
  firstInstanceType: ${default.types[0].id}
Using getInstanceTypes
Two invocation forms are available. The direct form accepts plain arguments and either blocks until the result value is available, or returns a Promise-wrapped result. The output form accepts Input-wrapped arguments and returns an Output-wrapped result.
function getInstanceTypes(args: GetInstanceTypesArgs, opts?: InvokeOptions): Promise<GetInstanceTypesResult>
function getInstanceTypesOutput(args: GetInstanceTypesOutputArgs, opts?: InvokeOptions): Output<GetInstanceTypesResult>def get_instance_types(cluster_type: Optional[str] = None,
                       destination_resource: Optional[str] = None,
                       instance_charge_type: Optional[str] = None,
                       instance_type: Optional[str] = None,
                       output_file: Optional[str] = None,
                       support_local_storage: Optional[bool] = None,
                       support_node_types: Optional[Sequence[str]] = None,
                       zone_id: Optional[str] = None,
                       opts: Optional[InvokeOptions] = None) -> GetInstanceTypesResult
def get_instance_types_output(cluster_type: Optional[pulumi.Input[str]] = None,
                       destination_resource: Optional[pulumi.Input[str]] = None,
                       instance_charge_type: Optional[pulumi.Input[str]] = None,
                       instance_type: Optional[pulumi.Input[str]] = None,
                       output_file: Optional[pulumi.Input[str]] = None,
                       support_local_storage: Optional[pulumi.Input[bool]] = None,
                       support_node_types: Optional[pulumi.Input[Sequence[pulumi.Input[str]]]] = None,
                       zone_id: Optional[pulumi.Input[str]] = None,
                       opts: Optional[InvokeOptions] = None) -> Output[GetInstanceTypesResult]func GetInstanceTypes(ctx *Context, args *GetInstanceTypesArgs, opts ...InvokeOption) (*GetInstanceTypesResult, error)
func GetInstanceTypesOutput(ctx *Context, args *GetInstanceTypesOutputArgs, opts ...InvokeOption) GetInstanceTypesResultOutput> Note: This function is named GetInstanceTypes in the Go SDK.
public static class GetInstanceTypes 
{
    public static Task<GetInstanceTypesResult> InvokeAsync(GetInstanceTypesArgs args, InvokeOptions? opts = null)
    public static Output<GetInstanceTypesResult> Invoke(GetInstanceTypesInvokeArgs args, InvokeOptions? opts = null)
}public static CompletableFuture<GetInstanceTypesResult> getInstanceTypes(GetInstanceTypesArgs args, InvokeOptions options)
public static Output<GetInstanceTypesResult> getInstanceTypes(GetInstanceTypesArgs args, InvokeOptions options)
fn::invoke:
  function: alicloud:emr/getInstanceTypes:getInstanceTypes
  arguments:
    # arguments dictionaryThe following arguments are supported:
- ClusterType string
- The cluster type of the emr cluster instance. Possible values: HADOOP,KAFKA,ZOOKEEPER,DRUID.
- DestinationResource string
- The destination resource of emr cluster instance
- InstanceCharge stringType 
- Filter the results by charge type. Valid values: PrePaidandPostPaid. Default toPostPaid.
- InstanceType string
- Filter the specific ecs instance type to create emr cluster.
- OutputFile string
- File name where to save data source results (after running pulumi preview).
- SupportLocal boolStorage 
- Whether the current storage disk is local or not.
- SupportNode List<string>Types 
- The specific supported node type list. Possible values may be any one or combination of these: ["MASTER", "CORE", "TASK", "GATEWAY"]
- ZoneId string
- The supported resources of specific zoneId.
- ClusterType string
- The cluster type of the emr cluster instance. Possible values: HADOOP,KAFKA,ZOOKEEPER,DRUID.
- DestinationResource string
- The destination resource of emr cluster instance
- InstanceCharge stringType 
- Filter the results by charge type. Valid values: PrePaidandPostPaid. Default toPostPaid.
- InstanceType string
- Filter the specific ecs instance type to create emr cluster.
- OutputFile string
- File name where to save data source results (after running pulumi preview).
- SupportLocal boolStorage 
- Whether the current storage disk is local or not.
- SupportNode []stringTypes 
- The specific supported node type list. Possible values may be any one or combination of these: ["MASTER", "CORE", "TASK", "GATEWAY"]
- ZoneId string
- The supported resources of specific zoneId.
- clusterType String
- The cluster type of the emr cluster instance. Possible values: HADOOP,KAFKA,ZOOKEEPER,DRUID.
- destinationResource String
- The destination resource of emr cluster instance
- instanceCharge StringType 
- Filter the results by charge type. Valid values: PrePaidandPostPaid. Default toPostPaid.
- instanceType String
- Filter the specific ecs instance type to create emr cluster.
- outputFile String
- File name where to save data source results (after running pulumi preview).
- supportLocal BooleanStorage 
- Whether the current storage disk is local or not.
- supportNode List<String>Types 
- The specific supported node type list. Possible values may be any one or combination of these: ["MASTER", "CORE", "TASK", "GATEWAY"]
- zoneId String
- The supported resources of specific zoneId.
- clusterType string
- The cluster type of the emr cluster instance. Possible values: HADOOP,KAFKA,ZOOKEEPER,DRUID.
- destinationResource string
- The destination resource of emr cluster instance
- instanceCharge stringType 
- Filter the results by charge type. Valid values: PrePaidandPostPaid. Default toPostPaid.
- instanceType string
- Filter the specific ecs instance type to create emr cluster.
- outputFile string
- File name where to save data source results (after running pulumi preview).
- supportLocal booleanStorage 
- Whether the current storage disk is local or not.
- supportNode string[]Types 
- The specific supported node type list. Possible values may be any one or combination of these: ["MASTER", "CORE", "TASK", "GATEWAY"]
- zoneId string
- The supported resources of specific zoneId.
- cluster_type str
- The cluster type of the emr cluster instance. Possible values: HADOOP,KAFKA,ZOOKEEPER,DRUID.
- destination_resource str
- The destination resource of emr cluster instance
- instance_charge_ strtype 
- Filter the results by charge type. Valid values: PrePaidandPostPaid. Default toPostPaid.
- instance_type str
- Filter the specific ecs instance type to create emr cluster.
- output_file str
- File name where to save data source results (after running pulumi preview).
- support_local_ boolstorage 
- Whether the current storage disk is local or not.
- support_node_ Sequence[str]types 
- The specific supported node type list. Possible values may be any one or combination of these: ["MASTER", "CORE", "TASK", "GATEWAY"]
- zone_id str
- The supported resources of specific zoneId.
- clusterType String
- The cluster type of the emr cluster instance. Possible values: HADOOP,KAFKA,ZOOKEEPER,DRUID.
- destinationResource String
- The destination resource of emr cluster instance
- instanceCharge StringType 
- Filter the results by charge type. Valid values: PrePaidandPostPaid. Default toPostPaid.
- instanceType String
- Filter the specific ecs instance type to create emr cluster.
- outputFile String
- File name where to save data source results (after running pulumi preview).
- supportLocal BooleanStorage 
- Whether the current storage disk is local or not.
- supportNode List<String>Types 
- The specific supported node type list. Possible values may be any one or combination of these: ["MASTER", "CORE", "TASK", "GATEWAY"]
- zoneId String
- The supported resources of specific zoneId.
getInstanceTypes Result
The following output properties are available:
- ClusterType string
- DestinationResource string
- Id string
- The provider-assigned unique ID for this managed resource.
- Ids List<string>
- A list of emr instance types IDs.
- InstanceCharge stringType 
- Types
List<Pulumi.Ali Cloud. Emr. Outputs. Get Instance Types Type> 
- A list of emr instance types. Each element contains the following attributes:
- InstanceType string
- OutputFile string
- SupportLocal boolStorage 
- SupportNode List<string>Types 
- ZoneId string
- The available zone id in Alibaba Cloud account
- ClusterType string
- DestinationResource string
- Id string
- The provider-assigned unique ID for this managed resource.
- Ids []string
- A list of emr instance types IDs.
- InstanceCharge stringType 
- Types
[]GetInstance Types Type 
- A list of emr instance types. Each element contains the following attributes:
- InstanceType string
- OutputFile string
- SupportLocal boolStorage 
- SupportNode []stringTypes 
- ZoneId string
- The available zone id in Alibaba Cloud account
- clusterType String
- destinationResource String
- id String
- The provider-assigned unique ID for this managed resource.
- ids List<String>
- A list of emr instance types IDs.
- instanceCharge StringType 
- types
List<GetInstance Types Type> 
- A list of emr instance types. Each element contains the following attributes:
- instanceType String
- outputFile String
- supportLocal BooleanStorage 
- supportNode List<String>Types 
- zoneId String
- The available zone id in Alibaba Cloud account
- clusterType string
- destinationResource string
- id string
- The provider-assigned unique ID for this managed resource.
- ids string[]
- A list of emr instance types IDs.
- instanceCharge stringType 
- types
GetInstance Types Type[] 
- A list of emr instance types. Each element contains the following attributes:
- instanceType string
- outputFile string
- supportLocal booleanStorage 
- supportNode string[]Types 
- zoneId string
- The available zone id in Alibaba Cloud account
- cluster_type str
- destination_resource str
- id str
- The provider-assigned unique ID for this managed resource.
- ids Sequence[str]
- A list of emr instance types IDs.
- instance_charge_ strtype 
- types
Sequence[GetInstance Types Type] 
- A list of emr instance types. Each element contains the following attributes:
- instance_type str
- output_file str
- support_local_ boolstorage 
- support_node_ Sequence[str]types 
- zone_id str
- The available zone id in Alibaba Cloud account
- clusterType String
- destinationResource String
- id String
- The provider-assigned unique ID for this managed resource.
- ids List<String>
- A list of emr instance types IDs.
- instanceCharge StringType 
- types List<Property Map>
- A list of emr instance types. Each element contains the following attributes:
- instanceType String
- outputFile String
- supportLocal BooleanStorage 
- supportNode List<String>Types 
- zoneId String
- The available zone id in Alibaba Cloud account
Supporting Types
GetInstanceTypesType   
- Id string
- The ID of the instance type.
- LocalStorage intCapacity 
- Local capacity of the applied ecs instance for emr cluster. Unit: GB.
- ZoneId string
- The supported resources of specific zoneId.
- Id string
- The ID of the instance type.
- LocalStorage intCapacity 
- Local capacity of the applied ecs instance for emr cluster. Unit: GB.
- ZoneId string
- The supported resources of specific zoneId.
- id String
- The ID of the instance type.
- localStorage IntegerCapacity 
- Local capacity of the applied ecs instance for emr cluster. Unit: GB.
- zoneId String
- The supported resources of specific zoneId.
- id string
- The ID of the instance type.
- localStorage numberCapacity 
- Local capacity of the applied ecs instance for emr cluster. Unit: GB.
- zoneId string
- The supported resources of specific zoneId.
- id str
- The ID of the instance type.
- local_storage_ intcapacity 
- Local capacity of the applied ecs instance for emr cluster. Unit: GB.
- zone_id str
- The supported resources of specific zoneId.
- id String
- The ID of the instance type.
- localStorage NumberCapacity 
- Local capacity of the applied ecs instance for emr cluster. Unit: GB.
- zoneId String
- The supported resources of specific zoneId.
Package Details
- Repository
- Alibaba Cloud pulumi/pulumi-alicloud
- License
- Apache-2.0
- Notes
- This Pulumi package is based on the alicloudTerraform Provider.