oci.Core.InstanceConfiguration
Explore with Pulumi AI
This resource provides the Instance Configuration resource in Oracle Cloud Infrastructure Core service.
Creates an instance configuration. An instance configuration is a template that defines the settings to use when creating Compute instances.
Example Usage
import * as pulumi from "@pulumi/pulumi";
import * as oci from "@pulumi/oci";
const testInstanceConfiguration = new oci.core.InstanceConfiguration("test_instance_configuration", {
    compartmentId: compartmentId,
    definedTags: {
        "Operations.CostCenter": "42",
    },
    displayName: instanceConfigurationDisplayName,
    freeformTags: {
        Department: "Finance",
    },
    instanceDetails: {
        instanceType: instanceConfigurationInstanceDetailsInstanceType,
        blockVolumes: [{
            attachDetails: {
                type: instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsType,
                device: instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsDevice,
                displayName: instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsDisplayName,
                isPvEncryptionInTransitEnabled: instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsIsPvEncryptionInTransitEnabled,
                isReadOnly: instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsIsReadOnly,
                isShareable: instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsIsShareable,
                useChap: instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsUseChap,
            },
            createDetails: {
                autotunePolicies: [{
                    autotuneType: instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsAutotunePoliciesAutotuneType,
                    maxVpusPerGb: instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsAutotunePoliciesMaxVpusPerGb,
                }],
                availabilityDomain: instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsAvailabilityDomain,
                backupPolicyId: testVolumeBackupPolicies.volumeBackupPolicies[0].id,
                blockVolumeReplicas: {
                    availabilityDomain: instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsBlockVolumeReplicasAvailabilityDomain,
                    displayName: instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsBlockVolumeReplicasDisplayName,
                },
                clusterPlacementGroupId: clusterPlacementGroupId,
                compartmentId: compartmentId,
                definedTags: {
                    "Operations.CostCenter": "42",
                },
                displayName: instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsDisplayName,
                freeformTags: {
                    Department: "Finance",
                },
                isAutoTuneEnabled: instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsIsAutoTuneEnabled,
                kmsKeyId: testKey.id,
                sizeInGbs: instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsSizeInGbs,
                sourceDetails: {
                    type: instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsSourceDetailsType,
                    id: instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsSourceDetailsId,
                },
                vpusPerGb: instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsVpusPerGb,
            },
            volumeId: testVolume.id,
        }],
        launchDetails: {
            agentConfig: {
                areAllPluginsDisabled: instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigAreAllPluginsDisabled,
                isManagementDisabled: instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigIsManagementDisabled,
                isMonitoringDisabled: instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigIsMonitoringDisabled,
                pluginsConfigs: [{
                    desiredState: instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigDesiredState,
                    name: instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigName,
                }],
            },
            availabilityConfig: {
                isLiveMigrationPreferred: instanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigIsLiveMigrationPreferred,
                recoveryAction: instanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigRecoveryAction,
            },
            availabilityDomain: instanceConfigurationInstanceDetailsLaunchDetailsAvailabilityDomain,
            capacityReservationId: testCapacityReservation.id,
            clusterPlacementGroupId: testGroup.id,
            compartmentId: compartmentId,
            createVnicDetails: {
                assignIpv6ip: instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignIpv6ip,
                assignPrivateDnsRecord: instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignPrivateDnsRecord,
                assignPublicIp: instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignPublicIp,
                definedTags: {
                    "Operations.CostCenter": "42",
                },
                displayName: instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsDisplayName,
                freeformTags: {
                    Department: "Finance",
                },
                hostnameLabel: instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsHostnameLabel,
                ipv6addressIpv6subnetCidrPairDetails: [{
                    ipv6address: instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6address,
                    ipv6subnetCidr: instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6subnetCidr,
                }],
                nsgIds: instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsNsgIds,
                privateIp: instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsPrivateIp,
                skipSourceDestCheck: instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsSkipSourceDestCheck,
                subnetId: testSubnet.id,
            },
            dedicatedVmHostId: testDedicatedVmHost.id,
            definedTags: {
                "Operations.CostCenter": "42",
            },
            displayName: instanceConfigurationInstanceDetailsLaunchDetailsDisplayName,
            extendedMetadata: instanceConfigurationInstanceDetailsLaunchDetailsExtendedMetadata,
            faultDomain: instanceConfigurationInstanceDetailsLaunchDetailsFaultDomain,
            freeformTags: {
                Department: "Finance",
            },
            instanceOptions: {
                areLegacyImdsEndpointsDisabled: instanceConfigurationInstanceDetailsLaunchDetailsInstanceOptionsAreLegacyImdsEndpointsDisabled,
            },
            ipxeScript: instanceConfigurationInstanceDetailsLaunchDetailsIpxeScript,
            isPvEncryptionInTransitEnabled: instanceConfigurationInstanceDetailsLaunchDetailsIsPvEncryptionInTransitEnabled,
            launchMode: instanceConfigurationInstanceDetailsLaunchDetailsLaunchMode,
            launchOptions: {
                bootVolumeType: instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsBootVolumeType,
                firmware: instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsFirmware,
                isConsistentVolumeNamingEnabled: instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsIsConsistentVolumeNamingEnabled,
                isPvEncryptionInTransitEnabled: instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsIsPvEncryptionInTransitEnabled,
                networkType: instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsNetworkType,
                remoteDataVolumeType: instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsRemoteDataVolumeType,
            },
            metadata: instanceConfigurationInstanceDetailsLaunchDetailsMetadata,
            platformConfig: {
                type: instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigType,
                areVirtualInstructionsEnabled: instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigAreVirtualInstructionsEnabled,
                configMap: instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigConfigMap,
                isAccessControlServiceEnabled: instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsAccessControlServiceEnabled,
                isInputOutputMemoryManagementUnitEnabled: instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsInputOutputMemoryManagementUnitEnabled,
                isMeasuredBootEnabled: instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsMeasuredBootEnabled,
                isMemoryEncryptionEnabled: instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsMemoryEncryptionEnabled,
                isSecureBootEnabled: instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsSecureBootEnabled,
                isSymmetricMultiThreadingEnabled: instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsSymmetricMultiThreadingEnabled,
                isTrustedPlatformModuleEnabled: instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsTrustedPlatformModuleEnabled,
                numaNodesPerSocket: instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigNumaNodesPerSocket,
                percentageOfCoresEnabled: instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigPercentageOfCoresEnabled,
            },
            preemptibleInstanceConfig: {
                preemptionAction: {
                    type: instanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionType,
                    preserveBootVolume: instanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionPreserveBootVolume,
                },
            },
            preferredMaintenanceAction: instanceConfigurationInstanceDetailsLaunchDetailsPreferredMaintenanceAction,
            shape: instanceConfigurationInstanceDetailsLaunchDetailsShape,
            shapeConfig: {
                baselineOcpuUtilization: instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigBaselineOcpuUtilization,
                memoryInGbs: instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigMemoryInGbs,
                nvmes: instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigNvmes,
                ocpus: instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigOcpus,
                vcpus: instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigVcpus,
            },
            sourceDetails: {
                sourceType: instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsSourceType,
                bootVolumeId: testBootVolume.id,
                bootVolumeSizeInGbs: instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsBootVolumeSizeInGbs,
                bootVolumeVpusPerGb: instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsBootVolumeVpusPerGb,
                imageId: testImage.id,
                kmsKeyId: testKey.id,
                instanceSourceImageFilterDetails: {
                    compartmentId: compartmentId,
                    definedTagsFilter: instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsDefinedTagsFilter,
                    operatingSystem: instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystem,
                    operatingSystemVersion: instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystemVersion,
                },
            },
        },
        options: [{
            blockVolumes: [{
                attachDetails: {
                    type: instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsType,
                    device: instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsDevice,
                    displayName: instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsDisplayName,
                    isPvEncryptionInTransitEnabled: instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsIsPvEncryptionInTransitEnabled,
                    isReadOnly: instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsIsReadOnly,
                    isShareable: instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsIsShareable,
                    useChap: instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsUseChap,
                },
                createDetails: {
                    autotunePolicies: [{
                        autotuneType: instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsAutotunePoliciesAutotuneType,
                        maxVpusPerGb: instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsAutotunePoliciesMaxVpusPerGb,
                    }],
                    availabilityDomain: instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsAvailabilityDomain,
                    backupPolicyId: testVolumeBackupPolicies.volumeBackupPolicies[0].id,
                    clusterPlacementGroupId: clusterPlacementGroupId,
                    compartmentId: compartmentId,
                    definedTags: {
                        "Operations.CostCenter": "42",
                    },
                    displayName: instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsDisplayName,
                    freeformTags: {
                        Department: "Finance",
                    },
                    kmsKeyId: testKey.id,
                    sizeInGbs: instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsSizeInGbs,
                    sourceDetails: {
                        type: instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsSourceDetailsType,
                        id: instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsSourceDetailsId,
                    },
                    vpusPerGb: instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsVpusPerGb,
                },
                volumeId: testVolume.id,
            }],
            launchDetails: {
                agentConfig: {
                    areAllPluginsDisabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigAreAllPluginsDisabled,
                    isManagementDisabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigIsManagementDisabled,
                    isMonitoringDisabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigIsMonitoringDisabled,
                    pluginsConfigs: [{
                        desiredState: instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigPluginsConfigDesiredState,
                        name: instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigPluginsConfigName,
                    }],
                },
                availabilityConfig: {
                    recoveryAction: instanceConfigurationInstanceDetailsOptionsLaunchDetailsAvailabilityConfigRecoveryAction,
                },
                availabilityDomain: instanceConfigurationInstanceDetailsOptionsLaunchDetailsAvailabilityDomain,
                capacityReservationId: testCapacityReservation.id,
                clusterPlacementGroupId: testGroup.id,
                compartmentId: compartmentId,
                createVnicDetails: {
                    assignIpv6ip: instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignIpv6ip,
                    assignPrivateDnsRecord: instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsAssignPrivateDnsRecord,
                    assignPublicIp: instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsAssignPublicIp,
                    definedTags: {
                        "Operations.CostCenter": "42",
                    },
                    displayName: instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsDisplayName,
                    freeformTags: {
                        Department: "Finance",
                    },
                    hostnameLabel: instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsHostnameLabel,
                    ipv6addressIpv6subnetCidrPairDetails: [{
                        ipv6address: instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6address,
                        ipv6subnetCidr: instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6subnetCidr,
                    }],
                    nsgIds: instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsNsgIds,
                    privateIp: instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsPrivateIp,
                    skipSourceDestCheck: instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsSkipSourceDestCheck,
                    subnetId: testSubnet.id,
                },
                dedicatedVmHostId: testDedicatedVmHost.id,
                definedTags: {
                    "Operations.CostCenter": "42",
                },
                displayName: instanceConfigurationInstanceDetailsOptionsLaunchDetailsDisplayName,
                extendedMetadata: instanceConfigurationInstanceDetailsOptionsLaunchDetailsExtendedMetadata,
                faultDomain: instanceConfigurationInstanceDetailsOptionsLaunchDetailsFaultDomain,
                freeformTags: {
                    Department: "Finance",
                },
                instanceOptions: {
                    areLegacyImdsEndpointsDisabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsInstanceOptionsAreLegacyImdsEndpointsDisabled,
                },
                ipxeScript: instanceConfigurationInstanceDetailsOptionsLaunchDetailsIpxeScript,
                isPvEncryptionInTransitEnabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsIsPvEncryptionInTransitEnabled,
                launchMode: instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchMode,
                launchOptions: {
                    bootVolumeType: instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsBootVolumeType,
                    firmware: instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsFirmware,
                    isConsistentVolumeNamingEnabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsIsConsistentVolumeNamingEnabled,
                    isPvEncryptionInTransitEnabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsIsPvEncryptionInTransitEnabled,
                    networkType: instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsNetworkType,
                    remoteDataVolumeType: instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsRemoteDataVolumeType,
                },
                metadata: instanceConfigurationInstanceDetailsOptionsLaunchDetailsMetadata,
                platformConfig: {
                    type: instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigType,
                    areVirtualInstructionsEnabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigAreVirtualInstructionsEnabled,
                    isAccessControlServiceEnabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsAccessControlServiceEnabled,
                    isInputOutputMemoryManagementUnitEnabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsInputOutputMemoryManagementUnitEnabled,
                    isMeasuredBootEnabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsMeasuredBootEnabled,
                    isMemoryEncryptionEnabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsMemoryEncryptionEnabled,
                    isSecureBootEnabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsSecureBootEnabled,
                    isSymmetricMultiThreadingEnabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsSymmetricMultiThreadingEnabled,
                    isTrustedPlatformModuleEnabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsTrustedPlatformModuleEnabled,
                    numaNodesPerSocket: instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigNumaNodesPerSocket,
                    percentageOfCoresEnabled: instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigPercentageOfCoresEnabled,
                },
                preemptibleInstanceConfig: {
                    preemptionAction: {
                        type: instanceConfigurationInstanceDetailsOptionsLaunchDetailsPreemptibleInstanceConfigPreemptionActionType,
                        preserveBootVolume: instanceConfigurationInstanceDetailsOptionsLaunchDetailsPreemptibleInstanceConfigPreemptionActionPreserveBootVolume,
                    },
                },
                preferredMaintenanceAction: instanceConfigurationInstanceDetailsOptionsLaunchDetailsPreferredMaintenanceAction,
                shape: instanceConfigurationInstanceDetailsOptionsLaunchDetailsShape,
                shapeConfig: {
                    baselineOcpuUtilization: instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigBaselineOcpuUtilization,
                    memoryInGbs: instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigMemoryInGbs,
                    nvmes: instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigNvmes,
                    ocpus: instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigOcpus,
                    vcpus: instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigVcpus,
                },
                sourceDetails: {
                    sourceType: instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsSourceType,
                    bootVolumeId: testBootVolume.id,
                    bootVolumeSizeInGbs: instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsBootVolumeSizeInGbs,
                    bootVolumeVpusPerGb: instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsBootVolumeVpusPerGb,
                    imageId: testImage.id,
                    instanceSourceImageFilterDetails: {
                        compartmentId: compartmentId,
                        definedTagsFilter: instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsDefinedTagsFilter,
                        operatingSystem: instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystem,
                        operatingSystemVersion: instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystemVersion,
                    },
                },
            },
            secondaryVnics: [{
                createVnicDetails: {
                    assignIpv6ip: instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsAssignIpv6ip,
                    assignPrivateDnsRecord: instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsAssignPrivateDnsRecord,
                    assignPublicIp: instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsAssignPublicIp,
                    definedTags: {
                        "Operations.CostCenter": "42",
                    },
                    displayName: instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsDisplayName,
                    freeformTags: {
                        Department: "Finance",
                    },
                    hostnameLabel: instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsHostnameLabel,
                    ipv6addressIpv6subnetCidrPairDetails: [{
                        ipv6address: instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6address,
                        ipv6subnetCidr: instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6subnetCidr,
                    }],
                    nsgIds: instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsNsgIds,
                    privateIp: instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsPrivateIp,
                    skipSourceDestCheck: instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsSkipSourceDestCheck,
                    subnetId: testSubnet.id,
                },
                displayName: instanceConfigurationInstanceDetailsOptionsSecondaryVnicsDisplayName,
                nicIndex: instanceConfigurationInstanceDetailsOptionsSecondaryVnicsNicIndex,
            }],
        }],
        secondaryVnics: [{
            createVnicDetails: {
                assignPrivateDnsRecord: instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsAssignPrivateDnsRecord,
                assignPublicIp: instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsAssignPublicIp,
                definedTags: {
                    "Operations.CostCenter": "42",
                },
                displayName: instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsDisplayName,
                freeformTags: {
                    Department: "Finance",
                },
                hostnameLabel: instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsHostnameLabel,
                nsgIds: instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsNsgIds,
                privateIp: instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsPrivateIp,
                skipSourceDestCheck: instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsSkipSourceDestCheck,
                subnetId: testSubnet.id,
            },
            displayName: instanceConfigurationInstanceDetailsSecondaryVnicsDisplayName,
            nicIndex: instanceConfigurationInstanceDetailsSecondaryVnicsNicIndex,
        }],
    },
    instanceId: testInstance.id,
    source: instanceConfigurationSource,
});
import pulumi
import pulumi_oci as oci
test_instance_configuration = oci.core.InstanceConfiguration("test_instance_configuration",
    compartment_id=compartment_id,
    defined_tags={
        "Operations.CostCenter": "42",
    },
    display_name=instance_configuration_display_name,
    freeform_tags={
        "Department": "Finance",
    },
    instance_details=oci.core.InstanceConfigurationInstanceDetailsArgs(
        instance_type=instance_configuration_instance_details_instance_type,
        block_volumes=[oci.core.InstanceConfigurationInstanceDetailsBlockVolumeArgs(
            attach_details=oci.core.InstanceConfigurationInstanceDetailsBlockVolumeAttachDetailsArgs(
                type=instance_configuration_instance_details_block_volumes_attach_details_type,
                device=instance_configuration_instance_details_block_volumes_attach_details_device,
                display_name=instance_configuration_instance_details_block_volumes_attach_details_display_name,
                is_pv_encryption_in_transit_enabled=instance_configuration_instance_details_block_volumes_attach_details_is_pv_encryption_in_transit_enabled,
                is_read_only=instance_configuration_instance_details_block_volumes_attach_details_is_read_only,
                is_shareable=instance_configuration_instance_details_block_volumes_attach_details_is_shareable,
                use_chap=instance_configuration_instance_details_block_volumes_attach_details_use_chap,
            ),
            create_details=oci.core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsArgs(
                autotune_policies=[oci.core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsAutotunePolicyArgs(
                    autotune_type=instance_configuration_instance_details_block_volumes_create_details_autotune_policies_autotune_type,
                    max_vpus_per_gb=instance_configuration_instance_details_block_volumes_create_details_autotune_policies_max_vpus_per_gb,
                )],
                availability_domain=instance_configuration_instance_details_block_volumes_create_details_availability_domain,
                backup_policy_id=test_volume_backup_policies["volumeBackupPolicies"][0]["id"],
                block_volume_replicas=oci.core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsBlockVolumeReplicasArgs(
                    availability_domain=instance_configuration_instance_details_block_volumes_create_details_block_volume_replicas_availability_domain,
                    display_name=instance_configuration_instance_details_block_volumes_create_details_block_volume_replicas_display_name,
                ),
                cluster_placement_group_id=cluster_placement_group_id,
                compartment_id=compartment_id,
                defined_tags={
                    "Operations.CostCenter": "42",
                },
                display_name=instance_configuration_instance_details_block_volumes_create_details_display_name,
                freeform_tags={
                    "Department": "Finance",
                },
                is_auto_tune_enabled=instance_configuration_instance_details_block_volumes_create_details_is_auto_tune_enabled,
                kms_key_id=test_key["id"],
                size_in_gbs=instance_configuration_instance_details_block_volumes_create_details_size_in_gbs,
                source_details=oci.core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsSourceDetailsArgs(
                    type=instance_configuration_instance_details_block_volumes_create_details_source_details_type,
                    id=instance_configuration_instance_details_block_volumes_create_details_source_details_id,
                ),
                vpus_per_gb=instance_configuration_instance_details_block_volumes_create_details_vpus_per_gb,
            ),
            volume_id=test_volume["id"],
        )],
        launch_details=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsArgs(
            agent_config=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigArgs(
                are_all_plugins_disabled=instance_configuration_instance_details_launch_details_agent_config_are_all_plugins_disabled,
                is_management_disabled=instance_configuration_instance_details_launch_details_agent_config_is_management_disabled,
                is_monitoring_disabled=instance_configuration_instance_details_launch_details_agent_config_is_monitoring_disabled,
                plugins_configs=[oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigArgs(
                    desired_state=instance_configuration_instance_details_launch_details_agent_config_plugins_config_desired_state,
                    name=instance_configuration_instance_details_launch_details_agent_config_plugins_config_name,
                )],
            ),
            availability_config=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigArgs(
                is_live_migration_preferred=instance_configuration_instance_details_launch_details_availability_config_is_live_migration_preferred,
                recovery_action=instance_configuration_instance_details_launch_details_availability_config_recovery_action,
            ),
            availability_domain=instance_configuration_instance_details_launch_details_availability_domain,
            capacity_reservation_id=test_capacity_reservation["id"],
            cluster_placement_group_id=test_group["id"],
            compartment_id=compartment_id,
            create_vnic_details=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsArgs(
                assign_ipv6ip=instance_configuration_instance_details_launch_details_create_vnic_details_assign_ipv6ip,
                assign_private_dns_record=instance_configuration_instance_details_launch_details_create_vnic_details_assign_private_dns_record,
                assign_public_ip=instance_configuration_instance_details_launch_details_create_vnic_details_assign_public_ip,
                defined_tags={
                    "Operations.CostCenter": "42",
                },
                display_name=instance_configuration_instance_details_launch_details_create_vnic_details_display_name,
                freeform_tags={
                    "Department": "Finance",
                },
                hostname_label=instance_configuration_instance_details_launch_details_create_vnic_details_hostname_label,
                ipv6address_ipv6subnet_cidr_pair_details=[oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs(
                    ipv6address=instance_configuration_instance_details_launch_details_create_vnic_details_ipv6address_ipv6subnet_cidr_pair_details_ipv6address,
                    ipv6subnet_cidr=instance_configuration_instance_details_launch_details_create_vnic_details_ipv6address_ipv6subnet_cidr_pair_details_ipv6subnet_cidr,
                )],
                nsg_ids=instance_configuration_instance_details_launch_details_create_vnic_details_nsg_ids,
                private_ip=instance_configuration_instance_details_launch_details_create_vnic_details_private_ip,
                skip_source_dest_check=instance_configuration_instance_details_launch_details_create_vnic_details_skip_source_dest_check,
                subnet_id=test_subnet["id"],
            ),
            dedicated_vm_host_id=test_dedicated_vm_host["id"],
            defined_tags={
                "Operations.CostCenter": "42",
            },
            display_name=instance_configuration_instance_details_launch_details_display_name,
            extended_metadata=instance_configuration_instance_details_launch_details_extended_metadata,
            fault_domain=instance_configuration_instance_details_launch_details_fault_domain,
            freeform_tags={
                "Department": "Finance",
            },
            instance_options=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsInstanceOptionsArgs(
                are_legacy_imds_endpoints_disabled=instance_configuration_instance_details_launch_details_instance_options_are_legacy_imds_endpoints_disabled,
            ),
            ipxe_script=instance_configuration_instance_details_launch_details_ipxe_script,
            is_pv_encryption_in_transit_enabled=instance_configuration_instance_details_launch_details_is_pv_encryption_in_transit_enabled,
            launch_mode=instance_configuration_instance_details_launch_details_launch_mode,
            launch_options=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsArgs(
                boot_volume_type=instance_configuration_instance_details_launch_details_launch_options_boot_volume_type,
                firmware=instance_configuration_instance_details_launch_details_launch_options_firmware,
                is_consistent_volume_naming_enabled=instance_configuration_instance_details_launch_details_launch_options_is_consistent_volume_naming_enabled,
                is_pv_encryption_in_transit_enabled=instance_configuration_instance_details_launch_details_launch_options_is_pv_encryption_in_transit_enabled,
                network_type=instance_configuration_instance_details_launch_details_launch_options_network_type,
                remote_data_volume_type=instance_configuration_instance_details_launch_details_launch_options_remote_data_volume_type,
            ),
            metadata=instance_configuration_instance_details_launch_details_metadata,
            platform_config=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigArgs(
                type=instance_configuration_instance_details_launch_details_platform_config_type,
                are_virtual_instructions_enabled=instance_configuration_instance_details_launch_details_platform_config_are_virtual_instructions_enabled,
                config_map=instance_configuration_instance_details_launch_details_platform_config_config_map,
                is_access_control_service_enabled=instance_configuration_instance_details_launch_details_platform_config_is_access_control_service_enabled,
                is_input_output_memory_management_unit_enabled=instance_configuration_instance_details_launch_details_platform_config_is_input_output_memory_management_unit_enabled,
                is_measured_boot_enabled=instance_configuration_instance_details_launch_details_platform_config_is_measured_boot_enabled,
                is_memory_encryption_enabled=instance_configuration_instance_details_launch_details_platform_config_is_memory_encryption_enabled,
                is_secure_boot_enabled=instance_configuration_instance_details_launch_details_platform_config_is_secure_boot_enabled,
                is_symmetric_multi_threading_enabled=instance_configuration_instance_details_launch_details_platform_config_is_symmetric_multi_threading_enabled,
                is_trusted_platform_module_enabled=instance_configuration_instance_details_launch_details_platform_config_is_trusted_platform_module_enabled,
                numa_nodes_per_socket=instance_configuration_instance_details_launch_details_platform_config_numa_nodes_per_socket,
                percentage_of_cores_enabled=instance_configuration_instance_details_launch_details_platform_config_percentage_of_cores_enabled,
            ),
            preemptible_instance_config=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigArgs(
                preemption_action=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs(
                    type=instance_configuration_instance_details_launch_details_preemptible_instance_config_preemption_action_type,
                    preserve_boot_volume=instance_configuration_instance_details_launch_details_preemptible_instance_config_preemption_action_preserve_boot_volume,
                ),
            ),
            preferred_maintenance_action=instance_configuration_instance_details_launch_details_preferred_maintenance_action,
            shape=instance_configuration_instance_details_launch_details_shape,
            shape_config=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsShapeConfigArgs(
                baseline_ocpu_utilization=instance_configuration_instance_details_launch_details_shape_config_baseline_ocpu_utilization,
                memory_in_gbs=instance_configuration_instance_details_launch_details_shape_config_memory_in_gbs,
                nvmes=instance_configuration_instance_details_launch_details_shape_config_nvmes,
                ocpus=instance_configuration_instance_details_launch_details_shape_config_ocpus,
                vcpus=instance_configuration_instance_details_launch_details_shape_config_vcpus,
            ),
            source_details=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsArgs(
                source_type=instance_configuration_instance_details_launch_details_source_details_source_type,
                boot_volume_id=test_boot_volume["id"],
                boot_volume_size_in_gbs=instance_configuration_instance_details_launch_details_source_details_boot_volume_size_in_gbs,
                boot_volume_vpus_per_gb=instance_configuration_instance_details_launch_details_source_details_boot_volume_vpus_per_gb,
                image_id=test_image["id"],
                kms_key_id=test_key["id"],
                instance_source_image_filter_details=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs(
                    compartment_id=compartment_id,
                    defined_tags_filter=instance_configuration_instance_details_launch_details_source_details_instance_source_image_filter_details_defined_tags_filter,
                    operating_system=instance_configuration_instance_details_launch_details_source_details_instance_source_image_filter_details_operating_system,
                    operating_system_version=instance_configuration_instance_details_launch_details_source_details_instance_source_image_filter_details_operating_system_version,
                ),
            ),
        ),
        options=[oci.core.InstanceConfigurationInstanceDetailsOptionArgs(
            block_volumes=[oci.core.InstanceConfigurationInstanceDetailsOptionBlockVolumeArgs(
                attach_details=oci.core.InstanceConfigurationInstanceDetailsOptionBlockVolumeAttachDetailsArgs(
                    type=instance_configuration_instance_details_options_block_volumes_attach_details_type,
                    device=instance_configuration_instance_details_options_block_volumes_attach_details_device,
                    display_name=instance_configuration_instance_details_options_block_volumes_attach_details_display_name,
                    is_pv_encryption_in_transit_enabled=instance_configuration_instance_details_options_block_volumes_attach_details_is_pv_encryption_in_transit_enabled,
                    is_read_only=instance_configuration_instance_details_options_block_volumes_attach_details_is_read_only,
                    is_shareable=instance_configuration_instance_details_options_block_volumes_attach_details_is_shareable,
                    use_chap=instance_configuration_instance_details_options_block_volumes_attach_details_use_chap,
                ),
                create_details=oci.core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsArgs(
                    autotune_policies=[oci.core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsAutotunePolicyArgs(
                        autotune_type=instance_configuration_instance_details_options_block_volumes_create_details_autotune_policies_autotune_type,
                        max_vpus_per_gb=instance_configuration_instance_details_options_block_volumes_create_details_autotune_policies_max_vpus_per_gb,
                    )],
                    availability_domain=instance_configuration_instance_details_options_block_volumes_create_details_availability_domain,
                    backup_policy_id=test_volume_backup_policies["volumeBackupPolicies"][0]["id"],
                    cluster_placement_group_id=cluster_placement_group_id,
                    compartment_id=compartment_id,
                    defined_tags={
                        "Operations.CostCenter": "42",
                    },
                    display_name=instance_configuration_instance_details_options_block_volumes_create_details_display_name,
                    freeform_tags={
                        "Department": "Finance",
                    },
                    kms_key_id=test_key["id"],
                    size_in_gbs=instance_configuration_instance_details_options_block_volumes_create_details_size_in_gbs,
                    source_details=oci.core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsSourceDetailsArgs(
                        type=instance_configuration_instance_details_options_block_volumes_create_details_source_details_type,
                        id=instance_configuration_instance_details_options_block_volumes_create_details_source_details_id,
                    ),
                    vpus_per_gb=instance_configuration_instance_details_options_block_volumes_create_details_vpus_per_gb,
                ),
                volume_id=test_volume["id"],
            )],
            launch_details=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsArgs(
                agent_config=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigArgs(
                    are_all_plugins_disabled=instance_configuration_instance_details_options_launch_details_agent_config_are_all_plugins_disabled,
                    is_management_disabled=instance_configuration_instance_details_options_launch_details_agent_config_is_management_disabled,
                    is_monitoring_disabled=instance_configuration_instance_details_options_launch_details_agent_config_is_monitoring_disabled,
                    plugins_configs=[oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigPluginsConfigArgs(
                        desired_state=instance_configuration_instance_details_options_launch_details_agent_config_plugins_config_desired_state,
                        name=instance_configuration_instance_details_options_launch_details_agent_config_plugins_config_name,
                    )],
                ),
                availability_config=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAvailabilityConfigArgs(
                    recovery_action=instance_configuration_instance_details_options_launch_details_availability_config_recovery_action,
                ),
                availability_domain=instance_configuration_instance_details_options_launch_details_availability_domain,
                capacity_reservation_id=test_capacity_reservation["id"],
                cluster_placement_group_id=test_group["id"],
                compartment_id=compartment_id,
                create_vnic_details=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsArgs(
                    assign_ipv6ip=instance_configuration_instance_details_launch_details_create_vnic_details_assign_ipv6ip,
                    assign_private_dns_record=instance_configuration_instance_details_options_launch_details_create_vnic_details_assign_private_dns_record,
                    assign_public_ip=instance_configuration_instance_details_options_launch_details_create_vnic_details_assign_public_ip,
                    defined_tags={
                        "Operations.CostCenter": "42",
                    },
                    display_name=instance_configuration_instance_details_options_launch_details_create_vnic_details_display_name,
                    freeform_tags={
                        "Department": "Finance",
                    },
                    hostname_label=instance_configuration_instance_details_options_launch_details_create_vnic_details_hostname_label,
                    ipv6address_ipv6subnet_cidr_pair_details=[oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs(
                        ipv6address=instance_configuration_instance_details_launch_details_create_vnic_details_ipv6address_ipv6subnet_cidr_pair_details_ipv6address,
                        ipv6subnet_cidr=instance_configuration_instance_details_launch_details_create_vnic_details_ipv6address_ipv6subnet_cidr_pair_details_ipv6subnet_cidr,
                    )],
                    nsg_ids=instance_configuration_instance_details_options_launch_details_create_vnic_details_nsg_ids,
                    private_ip=instance_configuration_instance_details_options_launch_details_create_vnic_details_private_ip,
                    skip_source_dest_check=instance_configuration_instance_details_options_launch_details_create_vnic_details_skip_source_dest_check,
                    subnet_id=test_subnet["id"],
                ),
                dedicated_vm_host_id=test_dedicated_vm_host["id"],
                defined_tags={
                    "Operations.CostCenter": "42",
                },
                display_name=instance_configuration_instance_details_options_launch_details_display_name,
                extended_metadata=instance_configuration_instance_details_options_launch_details_extended_metadata,
                fault_domain=instance_configuration_instance_details_options_launch_details_fault_domain,
                freeform_tags={
                    "Department": "Finance",
                },
                instance_options=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsInstanceOptionsArgs(
                    are_legacy_imds_endpoints_disabled=instance_configuration_instance_details_options_launch_details_instance_options_are_legacy_imds_endpoints_disabled,
                ),
                ipxe_script=instance_configuration_instance_details_options_launch_details_ipxe_script,
                is_pv_encryption_in_transit_enabled=instance_configuration_instance_details_options_launch_details_is_pv_encryption_in_transit_enabled,
                launch_mode=instance_configuration_instance_details_options_launch_details_launch_mode,
                launch_options=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsLaunchOptionsArgs(
                    boot_volume_type=instance_configuration_instance_details_options_launch_details_launch_options_boot_volume_type,
                    firmware=instance_configuration_instance_details_options_launch_details_launch_options_firmware,
                    is_consistent_volume_naming_enabled=instance_configuration_instance_details_options_launch_details_launch_options_is_consistent_volume_naming_enabled,
                    is_pv_encryption_in_transit_enabled=instance_configuration_instance_details_options_launch_details_launch_options_is_pv_encryption_in_transit_enabled,
                    network_type=instance_configuration_instance_details_options_launch_details_launch_options_network_type,
                    remote_data_volume_type=instance_configuration_instance_details_options_launch_details_launch_options_remote_data_volume_type,
                ),
                metadata=instance_configuration_instance_details_options_launch_details_metadata,
                platform_config=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPlatformConfigArgs(
                    type=instance_configuration_instance_details_options_launch_details_platform_config_type,
                    are_virtual_instructions_enabled=instance_configuration_instance_details_options_launch_details_platform_config_are_virtual_instructions_enabled,
                    is_access_control_service_enabled=instance_configuration_instance_details_options_launch_details_platform_config_is_access_control_service_enabled,
                    is_input_output_memory_management_unit_enabled=instance_configuration_instance_details_options_launch_details_platform_config_is_input_output_memory_management_unit_enabled,
                    is_measured_boot_enabled=instance_configuration_instance_details_options_launch_details_platform_config_is_measured_boot_enabled,
                    is_memory_encryption_enabled=instance_configuration_instance_details_options_launch_details_platform_config_is_memory_encryption_enabled,
                    is_secure_boot_enabled=instance_configuration_instance_details_options_launch_details_platform_config_is_secure_boot_enabled,
                    is_symmetric_multi_threading_enabled=instance_configuration_instance_details_options_launch_details_platform_config_is_symmetric_multi_threading_enabled,
                    is_trusted_platform_module_enabled=instance_configuration_instance_details_options_launch_details_platform_config_is_trusted_platform_module_enabled,
                    numa_nodes_per_socket=instance_configuration_instance_details_options_launch_details_platform_config_numa_nodes_per_socket,
                    percentage_of_cores_enabled=instance_configuration_instance_details_options_launch_details_platform_config_percentage_of_cores_enabled,
                ),
                preemptible_instance_config=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigArgs(
                    preemption_action=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs(
                        type=instance_configuration_instance_details_options_launch_details_preemptible_instance_config_preemption_action_type,
                        preserve_boot_volume=instance_configuration_instance_details_options_launch_details_preemptible_instance_config_preemption_action_preserve_boot_volume,
                    ),
                ),
                preferred_maintenance_action=instance_configuration_instance_details_options_launch_details_preferred_maintenance_action,
                shape=instance_configuration_instance_details_options_launch_details_shape,
                shape_config=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsShapeConfigArgs(
                    baseline_ocpu_utilization=instance_configuration_instance_details_options_launch_details_shape_config_baseline_ocpu_utilization,
                    memory_in_gbs=instance_configuration_instance_details_options_launch_details_shape_config_memory_in_gbs,
                    nvmes=instance_configuration_instance_details_options_launch_details_shape_config_nvmes,
                    ocpus=instance_configuration_instance_details_options_launch_details_shape_config_ocpus,
                    vcpus=instance_configuration_instance_details_options_launch_details_shape_config_vcpus,
                ),
                source_details=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsArgs(
                    source_type=instance_configuration_instance_details_options_launch_details_source_details_source_type,
                    boot_volume_id=test_boot_volume["id"],
                    boot_volume_size_in_gbs=instance_configuration_instance_details_options_launch_details_source_details_boot_volume_size_in_gbs,
                    boot_volume_vpus_per_gb=instance_configuration_instance_details_options_launch_details_source_details_boot_volume_vpus_per_gb,
                    image_id=test_image["id"],
                    instance_source_image_filter_details=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs(
                        compartment_id=compartment_id,
                        defined_tags_filter=instance_configuration_instance_details_options_launch_details_source_details_instance_source_image_filter_details_defined_tags_filter,
                        operating_system=instance_configuration_instance_details_options_launch_details_source_details_instance_source_image_filter_details_operating_system,
                        operating_system_version=instance_configuration_instance_details_options_launch_details_source_details_instance_source_image_filter_details_operating_system_version,
                    ),
                ),
            ),
            secondary_vnics=[oci.core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicArgs(
                create_vnic_details=oci.core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsArgs(
                    assign_ipv6ip=instance_configuration_instance_details_secondary_vnics_create_vnic_details_assign_ipv6ip,
                    assign_private_dns_record=instance_configuration_instance_details_options_secondary_vnics_create_vnic_details_assign_private_dns_record,
                    assign_public_ip=instance_configuration_instance_details_options_secondary_vnics_create_vnic_details_assign_public_ip,
                    defined_tags={
                        "Operations.CostCenter": "42",
                    },
                    display_name=instance_configuration_instance_details_options_secondary_vnics_create_vnic_details_display_name,
                    freeform_tags={
                        "Department": "Finance",
                    },
                    hostname_label=instance_configuration_instance_details_options_secondary_vnics_create_vnic_details_hostname_label,
                    ipv6address_ipv6subnet_cidr_pair_details=[oci.core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs(
                        ipv6address=instance_configuration_instance_details_secondary_vnics_create_vnic_details_ipv6address_ipv6subnet_cidr_pair_details_ipv6address,
                        ipv6subnet_cidr=instance_configuration_instance_details_secondary_vnics_create_vnic_details_ipv6address_ipv6subnet_cidr_pair_details_ipv6subnet_cidr,
                    )],
                    nsg_ids=instance_configuration_instance_details_options_secondary_vnics_create_vnic_details_nsg_ids,
                    private_ip=instance_configuration_instance_details_options_secondary_vnics_create_vnic_details_private_ip,
                    skip_source_dest_check=instance_configuration_instance_details_options_secondary_vnics_create_vnic_details_skip_source_dest_check,
                    subnet_id=test_subnet["id"],
                ),
                display_name=instance_configuration_instance_details_options_secondary_vnics_display_name,
                nic_index=instance_configuration_instance_details_options_secondary_vnics_nic_index,
            )],
        )],
        secondary_vnics=[oci.core.InstanceConfigurationInstanceDetailsSecondaryVnicArgs(
            create_vnic_details=oci.core.InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsArgs(
                assign_private_dns_record=instance_configuration_instance_details_secondary_vnics_create_vnic_details_assign_private_dns_record,
                assign_public_ip=instance_configuration_instance_details_secondary_vnics_create_vnic_details_assign_public_ip,
                defined_tags={
                    "Operations.CostCenter": "42",
                },
                display_name=instance_configuration_instance_details_secondary_vnics_create_vnic_details_display_name,
                freeform_tags={
                    "Department": "Finance",
                },
                hostname_label=instance_configuration_instance_details_secondary_vnics_create_vnic_details_hostname_label,
                nsg_ids=instance_configuration_instance_details_secondary_vnics_create_vnic_details_nsg_ids,
                private_ip=instance_configuration_instance_details_secondary_vnics_create_vnic_details_private_ip,
                skip_source_dest_check=instance_configuration_instance_details_secondary_vnics_create_vnic_details_skip_source_dest_check,
                subnet_id=test_subnet["id"],
            ),
            display_name=instance_configuration_instance_details_secondary_vnics_display_name,
            nic_index=instance_configuration_instance_details_secondary_vnics_nic_index,
        )],
    ),
    instance_id=test_instance["id"],
    source=instance_configuration_source)
package main
import (
	"github.com/pulumi/pulumi-oci/sdk/go/oci/Core"
	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
	pulumi.Run(func(ctx *pulumi.Context) error {
		_, err := Core.NewInstanceConfiguration(ctx, "test_instance_configuration", &Core.InstanceConfigurationArgs{
			CompartmentId: pulumi.Any(compartmentId),
			DefinedTags: pulumi.Map{
				"Operations.CostCenter": pulumi.Any("42"),
			},
			DisplayName: pulumi.Any(instanceConfigurationDisplayName),
			FreeformTags: pulumi.Map{
				"Department": pulumi.Any("Finance"),
			},
			InstanceDetails: &core.InstanceConfigurationInstanceDetailsArgs{
				InstanceType: pulumi.Any(instanceConfigurationInstanceDetailsInstanceType),
				BlockVolumes: core.InstanceConfigurationInstanceDetailsBlockVolumeArray{
					&core.InstanceConfigurationInstanceDetailsBlockVolumeArgs{
						AttachDetails: &core.InstanceConfigurationInstanceDetailsBlockVolumeAttachDetailsArgs{
							Type:                           pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsType),
							Device:                         pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsDevice),
							DisplayName:                    pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsDisplayName),
							IsPvEncryptionInTransitEnabled: pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsIsPvEncryptionInTransitEnabled),
							IsReadOnly:                     pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsIsReadOnly),
							IsShareable:                    pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsIsShareable),
							UseChap:                        pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsUseChap),
						},
						CreateDetails: &core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsArgs{
							AutotunePolicies: core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsAutotunePolicyArray{
								&core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsAutotunePolicyArgs{
									AutotuneType: pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsAutotunePoliciesAutotuneType),
									MaxVpusPerGb: pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsAutotunePoliciesMaxVpusPerGb),
								},
							},
							AvailabilityDomain: pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsAvailabilityDomain),
							BackupPolicyId:     pulumi.Any(testVolumeBackupPolicies.VolumeBackupPolicies[0].Id),
							BlockVolumeReplicas: &core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsBlockVolumeReplicasArgs{
								AvailabilityDomain: pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsBlockVolumeReplicasAvailabilityDomain),
								DisplayName:        pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsBlockVolumeReplicasDisplayName),
							},
							ClusterPlacementGroupId: pulumi.Any(clusterPlacementGroupId),
							CompartmentId:           pulumi.Any(compartmentId),
							DefinedTags: pulumi.Map{
								"Operations.CostCenter": pulumi.Any("42"),
							},
							DisplayName: pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsDisplayName),
							FreeformTags: pulumi.Map{
								"Department": pulumi.Any("Finance"),
							},
							IsAutoTuneEnabled: pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsIsAutoTuneEnabled),
							KmsKeyId:          pulumi.Any(testKey.Id),
							SizeInGbs:         pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsSizeInGbs),
							SourceDetails: &core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsSourceDetailsArgs{
								Type: pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsSourceDetailsType),
								Id:   pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsSourceDetailsId),
							},
							VpusPerGb: pulumi.Any(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsVpusPerGb),
						},
						VolumeId: pulumi.Any(testVolume.Id),
					},
				},
				LaunchDetails: &core.InstanceConfigurationInstanceDetailsLaunchDetailsArgs{
					AgentConfig: &core.InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigArgs{
						AreAllPluginsDisabled: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigAreAllPluginsDisabled),
						IsManagementDisabled:  pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigIsManagementDisabled),
						IsMonitoringDisabled:  pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigIsMonitoringDisabled),
						PluginsConfigs: core.InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigArray{
							&core.InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigArgs{
								DesiredState: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigDesiredState),
								Name:         pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigName),
							},
						},
					},
					AvailabilityConfig: &core.InstanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigArgs{
						IsLiveMigrationPreferred: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigIsLiveMigrationPreferred),
						RecoveryAction:           pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigRecoveryAction),
					},
					AvailabilityDomain:      pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsAvailabilityDomain),
					CapacityReservationId:   pulumi.Any(testCapacityReservation.Id),
					ClusterPlacementGroupId: pulumi.Any(testGroup.Id),
					CompartmentId:           pulumi.Any(compartmentId),
					CreateVnicDetails: &core.InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsArgs{
						AssignIpv6ip:           pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignIpv6ip),
						AssignPrivateDnsRecord: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignPrivateDnsRecord),
						AssignPublicIp:         pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignPublicIp),
						DefinedTags: pulumi.Map{
							"Operations.CostCenter": pulumi.Any("42"),
						},
						DisplayName: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsDisplayName),
						FreeformTags: pulumi.Map{
							"Department": pulumi.Any("Finance"),
						},
						HostnameLabel: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsHostnameLabel),
						Ipv6addressIpv6subnetCidrPairDetails: core.InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArray{
							&core.InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs{
								Ipv6address:    pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6address),
								Ipv6subnetCidr: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6subnetCidr),
							},
						},
						NsgIds:              pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsNsgIds),
						PrivateIp:           pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsPrivateIp),
						SkipSourceDestCheck: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsSkipSourceDestCheck),
						SubnetId:            pulumi.Any(testSubnet.Id),
					},
					DedicatedVmHostId: pulumi.Any(testDedicatedVmHost.Id),
					DefinedTags: pulumi.Map{
						"Operations.CostCenter": pulumi.Any("42"),
					},
					DisplayName:      pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsDisplayName),
					ExtendedMetadata: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsExtendedMetadata),
					FaultDomain:      pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsFaultDomain),
					FreeformTags: pulumi.Map{
						"Department": pulumi.Any("Finance"),
					},
					InstanceOptions: &core.InstanceConfigurationInstanceDetailsLaunchDetailsInstanceOptionsArgs{
						AreLegacyImdsEndpointsDisabled: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsInstanceOptionsAreLegacyImdsEndpointsDisabled),
					},
					IpxeScript:                     pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsIpxeScript),
					IsPvEncryptionInTransitEnabled: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsIsPvEncryptionInTransitEnabled),
					LaunchMode:                     pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsLaunchMode),
					LaunchOptions: &core.InstanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsArgs{
						BootVolumeType:                  pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsBootVolumeType),
						Firmware:                        pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsFirmware),
						IsConsistentVolumeNamingEnabled: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsIsConsistentVolumeNamingEnabled),
						IsPvEncryptionInTransitEnabled:  pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsIsPvEncryptionInTransitEnabled),
						NetworkType:                     pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsNetworkType),
						RemoteDataVolumeType:            pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsRemoteDataVolumeType),
					},
					Metadata: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsMetadata),
					PlatformConfig: &core.InstanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigArgs{
						Type:                                     pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigType),
						AreVirtualInstructionsEnabled:            pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigAreVirtualInstructionsEnabled),
						ConfigMap:                                pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigConfigMap),
						IsAccessControlServiceEnabled:            pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsAccessControlServiceEnabled),
						IsInputOutputMemoryManagementUnitEnabled: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsInputOutputMemoryManagementUnitEnabled),
						IsMeasuredBootEnabled:                    pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsMeasuredBootEnabled),
						IsMemoryEncryptionEnabled:                pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsMemoryEncryptionEnabled),
						IsSecureBootEnabled:                      pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsSecureBootEnabled),
						IsSymmetricMultiThreadingEnabled:         pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsSymmetricMultiThreadingEnabled),
						IsTrustedPlatformModuleEnabled:           pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsTrustedPlatformModuleEnabled),
						NumaNodesPerSocket:                       pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigNumaNodesPerSocket),
						PercentageOfCoresEnabled:                 pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigPercentageOfCoresEnabled),
					},
					PreemptibleInstanceConfig: &core.InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigArgs{
						PreemptionAction: &core.InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs{
							Type:               pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionType),
							PreserveBootVolume: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionPreserveBootVolume),
						},
					},
					PreferredMaintenanceAction: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsPreferredMaintenanceAction),
					Shape:                      pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsShape),
					ShapeConfig: &core.InstanceConfigurationInstanceDetailsLaunchDetailsShapeConfigArgs{
						BaselineOcpuUtilization: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigBaselineOcpuUtilization),
						MemoryInGbs:             pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigMemoryInGbs),
						Nvmes:                   pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigNvmes),
						Ocpus:                   pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigOcpus),
						Vcpus:                   pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigVcpus),
					},
					SourceDetails: &core.InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsArgs{
						SourceType:          pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsSourceType),
						BootVolumeId:        pulumi.Any(testBootVolume.Id),
						BootVolumeSizeInGbs: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsBootVolumeSizeInGbs),
						BootVolumeVpusPerGb: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsBootVolumeVpusPerGb),
						ImageId:             pulumi.Any(testImage.Id),
						KmsKeyId:            pulumi.Any(testKey.Id),
						InstanceSourceImageFilterDetails: &core.InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs{
							CompartmentId:          pulumi.Any(compartmentId),
							DefinedTagsFilter:      pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsDefinedTagsFilter),
							OperatingSystem:        pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystem),
							OperatingSystemVersion: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystemVersion),
						},
					},
				},
				Options: core.InstanceConfigurationInstanceDetailsOptionArray{
					&core.InstanceConfigurationInstanceDetailsOptionArgs{
						BlockVolumes: core.InstanceConfigurationInstanceDetailsOptionBlockVolumeArray{
							&core.InstanceConfigurationInstanceDetailsOptionBlockVolumeArgs{
								AttachDetails: &core.InstanceConfigurationInstanceDetailsOptionBlockVolumeAttachDetailsArgs{
									Type:                           pulumi.Any(instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsType),
									Device:                         pulumi.Any(instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsDevice),
									DisplayName:                    pulumi.Any(instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsDisplayName),
									IsPvEncryptionInTransitEnabled: pulumi.Any(instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsIsPvEncryptionInTransitEnabled),
									IsReadOnly:                     pulumi.Any(instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsIsReadOnly),
									IsShareable:                    pulumi.Any(instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsIsShareable),
									UseChap:                        pulumi.Any(instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsUseChap),
								},
								CreateDetails: &core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsArgs{
									AutotunePolicies: core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsAutotunePolicyArray{
										&core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsAutotunePolicyArgs{
											AutotuneType: pulumi.Any(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsAutotunePoliciesAutotuneType),
											MaxVpusPerGb: pulumi.Any(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsAutotunePoliciesMaxVpusPerGb),
										},
									},
									AvailabilityDomain:      pulumi.Any(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsAvailabilityDomain),
									BackupPolicyId:          pulumi.Any(testVolumeBackupPolicies.VolumeBackupPolicies[0].Id),
									ClusterPlacementGroupId: pulumi.Any(clusterPlacementGroupId),
									CompartmentId:           pulumi.Any(compartmentId),
									DefinedTags: pulumi.Map{
										"Operations.CostCenter": pulumi.Any("42"),
									},
									DisplayName: pulumi.Any(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsDisplayName),
									FreeformTags: pulumi.Map{
										"Department": pulumi.Any("Finance"),
									},
									KmsKeyId:  pulumi.Any(testKey.Id),
									SizeInGbs: pulumi.Any(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsSizeInGbs),
									SourceDetails: &core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsSourceDetailsArgs{
										Type: pulumi.Any(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsSourceDetailsType),
										Id:   pulumi.Any(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsSourceDetailsId),
									},
									VpusPerGb: pulumi.Any(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsVpusPerGb),
								},
								VolumeId: pulumi.Any(testVolume.Id),
							},
						},
						LaunchDetails: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsArgs{
							AgentConfig: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigArgs{
								AreAllPluginsDisabled: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigAreAllPluginsDisabled),
								IsManagementDisabled:  pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigIsManagementDisabled),
								IsMonitoringDisabled:  pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigIsMonitoringDisabled),
								PluginsConfigs: core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigPluginsConfigArray{
									&core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigPluginsConfigArgs{
										DesiredState: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigPluginsConfigDesiredState),
										Name:         pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigPluginsConfigName),
									},
								},
							},
							AvailabilityConfig: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAvailabilityConfigArgs{
								RecoveryAction: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsAvailabilityConfigRecoveryAction),
							},
							AvailabilityDomain:      pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsAvailabilityDomain),
							CapacityReservationId:   pulumi.Any(testCapacityReservation.Id),
							ClusterPlacementGroupId: pulumi.Any(testGroup.Id),
							CompartmentId:           pulumi.Any(compartmentId),
							CreateVnicDetails: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsArgs{
								AssignIpv6ip:           pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignIpv6ip),
								AssignPrivateDnsRecord: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsAssignPrivateDnsRecord),
								AssignPublicIp:         pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsAssignPublicIp),
								DefinedTags: pulumi.Map{
									"Operations.CostCenter": pulumi.Any("42"),
								},
								DisplayName: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsDisplayName),
								FreeformTags: pulumi.Map{
									"Department": pulumi.Any("Finance"),
								},
								HostnameLabel: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsHostnameLabel),
								Ipv6addressIpv6subnetCidrPairDetails: core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArray{
									&core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs{
										Ipv6address:    pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6address),
										Ipv6subnetCidr: pulumi.Any(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6subnetCidr),
									},
								},
								NsgIds:              pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsNsgIds),
								PrivateIp:           pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsPrivateIp),
								SkipSourceDestCheck: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsSkipSourceDestCheck),
								SubnetId:            pulumi.Any(testSubnet.Id),
							},
							DedicatedVmHostId: pulumi.Any(testDedicatedVmHost.Id),
							DefinedTags: pulumi.Map{
								"Operations.CostCenter": pulumi.Any("42"),
							},
							DisplayName:      pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsDisplayName),
							ExtendedMetadata: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsExtendedMetadata),
							FaultDomain:      pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsFaultDomain),
							FreeformTags: pulumi.Map{
								"Department": pulumi.Any("Finance"),
							},
							InstanceOptions: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsInstanceOptionsArgs{
								AreLegacyImdsEndpointsDisabled: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsInstanceOptionsAreLegacyImdsEndpointsDisabled),
							},
							IpxeScript:                     pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsIpxeScript),
							IsPvEncryptionInTransitEnabled: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsIsPvEncryptionInTransitEnabled),
							LaunchMode:                     pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchMode),
							LaunchOptions: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsLaunchOptionsArgs{
								BootVolumeType:                  pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsBootVolumeType),
								Firmware:                        pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsFirmware),
								IsConsistentVolumeNamingEnabled: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsIsConsistentVolumeNamingEnabled),
								IsPvEncryptionInTransitEnabled:  pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsIsPvEncryptionInTransitEnabled),
								NetworkType:                     pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsNetworkType),
								RemoteDataVolumeType:            pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsRemoteDataVolumeType),
							},
							Metadata: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsMetadata),
							PlatformConfig: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPlatformConfigArgs{
								Type:                                     pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigType),
								AreVirtualInstructionsEnabled:            pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigAreVirtualInstructionsEnabled),
								IsAccessControlServiceEnabled:            pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsAccessControlServiceEnabled),
								IsInputOutputMemoryManagementUnitEnabled: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsInputOutputMemoryManagementUnitEnabled),
								IsMeasuredBootEnabled:                    pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsMeasuredBootEnabled),
								IsMemoryEncryptionEnabled:                pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsMemoryEncryptionEnabled),
								IsSecureBootEnabled:                      pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsSecureBootEnabled),
								IsSymmetricMultiThreadingEnabled:         pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsSymmetricMultiThreadingEnabled),
								IsTrustedPlatformModuleEnabled:           pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsTrustedPlatformModuleEnabled),
								NumaNodesPerSocket:                       pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigNumaNodesPerSocket),
								PercentageOfCoresEnabled:                 pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigPercentageOfCoresEnabled),
							},
							PreemptibleInstanceConfig: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigArgs{
								PreemptionAction: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs{
									Type:               pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPreemptibleInstanceConfigPreemptionActionType),
									PreserveBootVolume: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPreemptibleInstanceConfigPreemptionActionPreserveBootVolume),
								},
							},
							PreferredMaintenanceAction: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPreferredMaintenanceAction),
							Shape:                      pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsShape),
							ShapeConfig: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsShapeConfigArgs{
								BaselineOcpuUtilization: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigBaselineOcpuUtilization),
								MemoryInGbs:             pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigMemoryInGbs),
								Nvmes:                   pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigNvmes),
								Ocpus:                   pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigOcpus),
								Vcpus:                   pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigVcpus),
							},
							SourceDetails: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsArgs{
								SourceType:          pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsSourceType),
								BootVolumeId:        pulumi.Any(testBootVolume.Id),
								BootVolumeSizeInGbs: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsBootVolumeSizeInGbs),
								BootVolumeVpusPerGb: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsBootVolumeVpusPerGb),
								ImageId:             pulumi.Any(testImage.Id),
								InstanceSourceImageFilterDetails: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs{
									CompartmentId:          pulumi.Any(compartmentId),
									DefinedTagsFilter:      pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsDefinedTagsFilter),
									OperatingSystem:        pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystem),
									OperatingSystemVersion: pulumi.Any(instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystemVersion),
								},
							},
						},
						SecondaryVnics: core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicArray{
							&core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicArgs{
								CreateVnicDetails: &core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsArgs{
									AssignIpv6ip:           pulumi.Any(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsAssignIpv6ip),
									AssignPrivateDnsRecord: pulumi.Any(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsAssignPrivateDnsRecord),
									AssignPublicIp:         pulumi.Any(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsAssignPublicIp),
									DefinedTags: pulumi.Map{
										"Operations.CostCenter": pulumi.Any("42"),
									},
									DisplayName: pulumi.Any(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsDisplayName),
									FreeformTags: pulumi.Map{
										"Department": pulumi.Any("Finance"),
									},
									HostnameLabel: pulumi.Any(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsHostnameLabel),
									Ipv6addressIpv6subnetCidrPairDetails: core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArray{
										&core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs{
											Ipv6address:    pulumi.Any(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6address),
											Ipv6subnetCidr: pulumi.Any(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6subnetCidr),
										},
									},
									NsgIds:              pulumi.Any(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsNsgIds),
									PrivateIp:           pulumi.Any(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsPrivateIp),
									SkipSourceDestCheck: pulumi.Any(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsSkipSourceDestCheck),
									SubnetId:            pulumi.Any(testSubnet.Id),
								},
								DisplayName: pulumi.Any(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsDisplayName),
								NicIndex:    pulumi.Any(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsNicIndex),
							},
						},
					},
				},
				SecondaryVnics: core.InstanceConfigurationInstanceDetailsSecondaryVnicArray{
					&core.InstanceConfigurationInstanceDetailsSecondaryVnicArgs{
						CreateVnicDetails: &core.InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsArgs{
							AssignPrivateDnsRecord: pulumi.Any(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsAssignPrivateDnsRecord),
							AssignPublicIp:         pulumi.Any(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsAssignPublicIp),
							DefinedTags: pulumi.Map{
								"Operations.CostCenter": pulumi.Any("42"),
							},
							DisplayName: pulumi.Any(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsDisplayName),
							FreeformTags: pulumi.Map{
								"Department": pulumi.Any("Finance"),
							},
							HostnameLabel:       pulumi.Any(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsHostnameLabel),
							NsgIds:              pulumi.Any(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsNsgIds),
							PrivateIp:           pulumi.Any(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsPrivateIp),
							SkipSourceDestCheck: pulumi.Any(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsSkipSourceDestCheck),
							SubnetId:            pulumi.Any(testSubnet.Id),
						},
						DisplayName: pulumi.Any(instanceConfigurationInstanceDetailsSecondaryVnicsDisplayName),
						NicIndex:    pulumi.Any(instanceConfigurationInstanceDetailsSecondaryVnicsNicIndex),
					},
				},
			},
			InstanceId: pulumi.Any(testInstance.Id),
			Source:     pulumi.Any(instanceConfigurationSource),
		})
		if err != nil {
			return err
		}
		return nil
	})
}
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Oci = Pulumi.Oci;
return await Deployment.RunAsync(() => 
{
    var testInstanceConfiguration = new Oci.Core.InstanceConfiguration("test_instance_configuration", new()
    {
        CompartmentId = compartmentId,
        DefinedTags = 
        {
            { "Operations.CostCenter", "42" },
        },
        DisplayName = instanceConfigurationDisplayName,
        FreeformTags = 
        {
            { "Department", "Finance" },
        },
        InstanceDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsArgs
        {
            InstanceType = instanceConfigurationInstanceDetailsInstanceType,
            BlockVolumes = new[]
            {
                new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsBlockVolumeArgs
                {
                    AttachDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsBlockVolumeAttachDetailsArgs
                    {
                        Type = instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsType,
                        Device = instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsDevice,
                        DisplayName = instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsDisplayName,
                        IsPvEncryptionInTransitEnabled = instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsIsPvEncryptionInTransitEnabled,
                        IsReadOnly = instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsIsReadOnly,
                        IsShareable = instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsIsShareable,
                        UseChap = instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsUseChap,
                    },
                    CreateDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsArgs
                    {
                        AutotunePolicies = new[]
                        {
                            new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsAutotunePolicyArgs
                            {
                                AutotuneType = instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsAutotunePoliciesAutotuneType,
                                MaxVpusPerGb = instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsAutotunePoliciesMaxVpusPerGb,
                            },
                        },
                        AvailabilityDomain = instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsAvailabilityDomain,
                        BackupPolicyId = testVolumeBackupPolicies.VolumeBackupPolicies[0].Id,
                        BlockVolumeReplicas = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsBlockVolumeReplicasArgs
                        {
                            AvailabilityDomain = instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsBlockVolumeReplicasAvailabilityDomain,
                            DisplayName = instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsBlockVolumeReplicasDisplayName,
                        },
                        ClusterPlacementGroupId = clusterPlacementGroupId,
                        CompartmentId = compartmentId,
                        DefinedTags = 
                        {
                            { "Operations.CostCenter", "42" },
                        },
                        DisplayName = instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsDisplayName,
                        FreeformTags = 
                        {
                            { "Department", "Finance" },
                        },
                        IsAutoTuneEnabled = instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsIsAutoTuneEnabled,
                        KmsKeyId = testKey.Id,
                        SizeInGbs = instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsSizeInGbs,
                        SourceDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsSourceDetailsArgs
                        {
                            Type = instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsSourceDetailsType,
                            Id = instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsSourceDetailsId,
                        },
                        VpusPerGb = instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsVpusPerGb,
                    },
                    VolumeId = testVolume.Id,
                },
            },
            LaunchDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsArgs
            {
                AgentConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigArgs
                {
                    AreAllPluginsDisabled = instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigAreAllPluginsDisabled,
                    IsManagementDisabled = instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigIsManagementDisabled,
                    IsMonitoringDisabled = instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigIsMonitoringDisabled,
                    PluginsConfigs = new[]
                    {
                        new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigArgs
                        {
                            DesiredState = instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigDesiredState,
                            Name = instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigName,
                        },
                    },
                },
                AvailabilityConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigArgs
                {
                    IsLiveMigrationPreferred = instanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigIsLiveMigrationPreferred,
                    RecoveryAction = instanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigRecoveryAction,
                },
                AvailabilityDomain = instanceConfigurationInstanceDetailsLaunchDetailsAvailabilityDomain,
                CapacityReservationId = testCapacityReservation.Id,
                ClusterPlacementGroupId = testGroup.Id,
                CompartmentId = compartmentId,
                CreateVnicDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsArgs
                {
                    AssignIpv6ip = instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignIpv6ip,
                    AssignPrivateDnsRecord = instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignPrivateDnsRecord,
                    AssignPublicIp = instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignPublicIp,
                    DefinedTags = 
                    {
                        { "Operations.CostCenter", "42" },
                    },
                    DisplayName = instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsDisplayName,
                    FreeformTags = 
                    {
                        { "Department", "Finance" },
                    },
                    HostnameLabel = instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsHostnameLabel,
                    Ipv6addressIpv6subnetCidrPairDetails = new[]
                    {
                        new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs
                        {
                            Ipv6address = instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6address,
                            Ipv6subnetCidr = instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6subnetCidr,
                        },
                    },
                    NsgIds = instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsNsgIds,
                    PrivateIp = instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsPrivateIp,
                    SkipSourceDestCheck = instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsSkipSourceDestCheck,
                    SubnetId = testSubnet.Id,
                },
                DedicatedVmHostId = testDedicatedVmHost.Id,
                DefinedTags = 
                {
                    { "Operations.CostCenter", "42" },
                },
                DisplayName = instanceConfigurationInstanceDetailsLaunchDetailsDisplayName,
                ExtendedMetadata = instanceConfigurationInstanceDetailsLaunchDetailsExtendedMetadata,
                FaultDomain = instanceConfigurationInstanceDetailsLaunchDetailsFaultDomain,
                FreeformTags = 
                {
                    { "Department", "Finance" },
                },
                InstanceOptions = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsInstanceOptionsArgs
                {
                    AreLegacyImdsEndpointsDisabled = instanceConfigurationInstanceDetailsLaunchDetailsInstanceOptionsAreLegacyImdsEndpointsDisabled,
                },
                IpxeScript = instanceConfigurationInstanceDetailsLaunchDetailsIpxeScript,
                IsPvEncryptionInTransitEnabled = instanceConfigurationInstanceDetailsLaunchDetailsIsPvEncryptionInTransitEnabled,
                LaunchMode = instanceConfigurationInstanceDetailsLaunchDetailsLaunchMode,
                LaunchOptions = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsArgs
                {
                    BootVolumeType = instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsBootVolumeType,
                    Firmware = instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsFirmware,
                    IsConsistentVolumeNamingEnabled = instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsIsConsistentVolumeNamingEnabled,
                    IsPvEncryptionInTransitEnabled = instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsIsPvEncryptionInTransitEnabled,
                    NetworkType = instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsNetworkType,
                    RemoteDataVolumeType = instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsRemoteDataVolumeType,
                },
                Metadata = instanceConfigurationInstanceDetailsLaunchDetailsMetadata,
                PlatformConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigArgs
                {
                    Type = instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigType,
                    AreVirtualInstructionsEnabled = instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigAreVirtualInstructionsEnabled,
                    ConfigMap = instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigConfigMap,
                    IsAccessControlServiceEnabled = instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsAccessControlServiceEnabled,
                    IsInputOutputMemoryManagementUnitEnabled = instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsInputOutputMemoryManagementUnitEnabled,
                    IsMeasuredBootEnabled = instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsMeasuredBootEnabled,
                    IsMemoryEncryptionEnabled = instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsMemoryEncryptionEnabled,
                    IsSecureBootEnabled = instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsSecureBootEnabled,
                    IsSymmetricMultiThreadingEnabled = instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsSymmetricMultiThreadingEnabled,
                    IsTrustedPlatformModuleEnabled = instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsTrustedPlatformModuleEnabled,
                    NumaNodesPerSocket = instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigNumaNodesPerSocket,
                    PercentageOfCoresEnabled = instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigPercentageOfCoresEnabled,
                },
                PreemptibleInstanceConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigArgs
                {
                    PreemptionAction = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs
                    {
                        Type = instanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionType,
                        PreserveBootVolume = instanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionPreserveBootVolume,
                    },
                },
                PreferredMaintenanceAction = instanceConfigurationInstanceDetailsLaunchDetailsPreferredMaintenanceAction,
                Shape = instanceConfigurationInstanceDetailsLaunchDetailsShape,
                ShapeConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsShapeConfigArgs
                {
                    BaselineOcpuUtilization = instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigBaselineOcpuUtilization,
                    MemoryInGbs = instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigMemoryInGbs,
                    Nvmes = instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigNvmes,
                    Ocpus = instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigOcpus,
                    Vcpus = instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigVcpus,
                },
                SourceDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsArgs
                {
                    SourceType = instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsSourceType,
                    BootVolumeId = testBootVolume.Id,
                    BootVolumeSizeInGbs = instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsBootVolumeSizeInGbs,
                    BootVolumeVpusPerGb = instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsBootVolumeVpusPerGb,
                    ImageId = testImage.Id,
                    KmsKeyId = testKey.Id,
                    InstanceSourceImageFilterDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs
                    {
                        CompartmentId = compartmentId,
                        DefinedTagsFilter = instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsDefinedTagsFilter,
                        OperatingSystem = instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystem,
                        OperatingSystemVersion = instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystemVersion,
                    },
                },
            },
            Options = new[]
            {
                new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionArgs
                {
                    BlockVolumes = new[]
                    {
                        new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionBlockVolumeArgs
                        {
                            AttachDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionBlockVolumeAttachDetailsArgs
                            {
                                Type = instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsType,
                                Device = instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsDevice,
                                DisplayName = instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsDisplayName,
                                IsPvEncryptionInTransitEnabled = instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsIsPvEncryptionInTransitEnabled,
                                IsReadOnly = instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsIsReadOnly,
                                IsShareable = instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsIsShareable,
                                UseChap = instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsUseChap,
                            },
                            CreateDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsArgs
                            {
                                AutotunePolicies = new[]
                                {
                                    new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsAutotunePolicyArgs
                                    {
                                        AutotuneType = instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsAutotunePoliciesAutotuneType,
                                        MaxVpusPerGb = instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsAutotunePoliciesMaxVpusPerGb,
                                    },
                                },
                                AvailabilityDomain = instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsAvailabilityDomain,
                                BackupPolicyId = testVolumeBackupPolicies.VolumeBackupPolicies[0].Id,
                                ClusterPlacementGroupId = clusterPlacementGroupId,
                                CompartmentId = compartmentId,
                                DefinedTags = 
                                {
                                    { "Operations.CostCenter", "42" },
                                },
                                DisplayName = instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsDisplayName,
                                FreeformTags = 
                                {
                                    { "Department", "Finance" },
                                },
                                KmsKeyId = testKey.Id,
                                SizeInGbs = instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsSizeInGbs,
                                SourceDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsSourceDetailsArgs
                                {
                                    Type = instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsSourceDetailsType,
                                    Id = instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsSourceDetailsId,
                                },
                                VpusPerGb = instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsVpusPerGb,
                            },
                            VolumeId = testVolume.Id,
                        },
                    },
                    LaunchDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsArgs
                    {
                        AgentConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigArgs
                        {
                            AreAllPluginsDisabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigAreAllPluginsDisabled,
                            IsManagementDisabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigIsManagementDisabled,
                            IsMonitoringDisabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigIsMonitoringDisabled,
                            PluginsConfigs = new[]
                            {
                                new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigPluginsConfigArgs
                                {
                                    DesiredState = instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigPluginsConfigDesiredState,
                                    Name = instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigPluginsConfigName,
                                },
                            },
                        },
                        AvailabilityConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAvailabilityConfigArgs
                        {
                            RecoveryAction = instanceConfigurationInstanceDetailsOptionsLaunchDetailsAvailabilityConfigRecoveryAction,
                        },
                        AvailabilityDomain = instanceConfigurationInstanceDetailsOptionsLaunchDetailsAvailabilityDomain,
                        CapacityReservationId = testCapacityReservation.Id,
                        ClusterPlacementGroupId = testGroup.Id,
                        CompartmentId = compartmentId,
                        CreateVnicDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsArgs
                        {
                            AssignIpv6ip = instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignIpv6ip,
                            AssignPrivateDnsRecord = instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsAssignPrivateDnsRecord,
                            AssignPublicIp = instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsAssignPublicIp,
                            DefinedTags = 
                            {
                                { "Operations.CostCenter", "42" },
                            },
                            DisplayName = instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsDisplayName,
                            FreeformTags = 
                            {
                                { "Department", "Finance" },
                            },
                            HostnameLabel = instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsHostnameLabel,
                            Ipv6addressIpv6subnetCidrPairDetails = new[]
                            {
                                new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs
                                {
                                    Ipv6address = instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6address,
                                    Ipv6subnetCidr = instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6subnetCidr,
                                },
                            },
                            NsgIds = instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsNsgIds,
                            PrivateIp = instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsPrivateIp,
                            SkipSourceDestCheck = instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsSkipSourceDestCheck,
                            SubnetId = testSubnet.Id,
                        },
                        DedicatedVmHostId = testDedicatedVmHost.Id,
                        DefinedTags = 
                        {
                            { "Operations.CostCenter", "42" },
                        },
                        DisplayName = instanceConfigurationInstanceDetailsOptionsLaunchDetailsDisplayName,
                        ExtendedMetadata = instanceConfigurationInstanceDetailsOptionsLaunchDetailsExtendedMetadata,
                        FaultDomain = instanceConfigurationInstanceDetailsOptionsLaunchDetailsFaultDomain,
                        FreeformTags = 
                        {
                            { "Department", "Finance" },
                        },
                        InstanceOptions = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsInstanceOptionsArgs
                        {
                            AreLegacyImdsEndpointsDisabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsInstanceOptionsAreLegacyImdsEndpointsDisabled,
                        },
                        IpxeScript = instanceConfigurationInstanceDetailsOptionsLaunchDetailsIpxeScript,
                        IsPvEncryptionInTransitEnabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsIsPvEncryptionInTransitEnabled,
                        LaunchMode = instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchMode,
                        LaunchOptions = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsLaunchOptionsArgs
                        {
                            BootVolumeType = instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsBootVolumeType,
                            Firmware = instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsFirmware,
                            IsConsistentVolumeNamingEnabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsIsConsistentVolumeNamingEnabled,
                            IsPvEncryptionInTransitEnabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsIsPvEncryptionInTransitEnabled,
                            NetworkType = instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsNetworkType,
                            RemoteDataVolumeType = instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsRemoteDataVolumeType,
                        },
                        Metadata = instanceConfigurationInstanceDetailsOptionsLaunchDetailsMetadata,
                        PlatformConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPlatformConfigArgs
                        {
                            Type = instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigType,
                            AreVirtualInstructionsEnabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigAreVirtualInstructionsEnabled,
                            IsAccessControlServiceEnabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsAccessControlServiceEnabled,
                            IsInputOutputMemoryManagementUnitEnabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsInputOutputMemoryManagementUnitEnabled,
                            IsMeasuredBootEnabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsMeasuredBootEnabled,
                            IsMemoryEncryptionEnabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsMemoryEncryptionEnabled,
                            IsSecureBootEnabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsSecureBootEnabled,
                            IsSymmetricMultiThreadingEnabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsSymmetricMultiThreadingEnabled,
                            IsTrustedPlatformModuleEnabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsTrustedPlatformModuleEnabled,
                            NumaNodesPerSocket = instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigNumaNodesPerSocket,
                            PercentageOfCoresEnabled = instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigPercentageOfCoresEnabled,
                        },
                        PreemptibleInstanceConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigArgs
                        {
                            PreemptionAction = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs
                            {
                                Type = instanceConfigurationInstanceDetailsOptionsLaunchDetailsPreemptibleInstanceConfigPreemptionActionType,
                                PreserveBootVolume = instanceConfigurationInstanceDetailsOptionsLaunchDetailsPreemptibleInstanceConfigPreemptionActionPreserveBootVolume,
                            },
                        },
                        PreferredMaintenanceAction = instanceConfigurationInstanceDetailsOptionsLaunchDetailsPreferredMaintenanceAction,
                        Shape = instanceConfigurationInstanceDetailsOptionsLaunchDetailsShape,
                        ShapeConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsShapeConfigArgs
                        {
                            BaselineOcpuUtilization = instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigBaselineOcpuUtilization,
                            MemoryInGbs = instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigMemoryInGbs,
                            Nvmes = instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigNvmes,
                            Ocpus = instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigOcpus,
                            Vcpus = instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigVcpus,
                        },
                        SourceDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsArgs
                        {
                            SourceType = instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsSourceType,
                            BootVolumeId = testBootVolume.Id,
                            BootVolumeSizeInGbs = instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsBootVolumeSizeInGbs,
                            BootVolumeVpusPerGb = instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsBootVolumeVpusPerGb,
                            ImageId = testImage.Id,
                            InstanceSourceImageFilterDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs
                            {
                                CompartmentId = compartmentId,
                                DefinedTagsFilter = instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsDefinedTagsFilter,
                                OperatingSystem = instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystem,
                                OperatingSystemVersion = instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystemVersion,
                            },
                        },
                    },
                    SecondaryVnics = new[]
                    {
                        new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionSecondaryVnicArgs
                        {
                            CreateVnicDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsArgs
                            {
                                AssignIpv6ip = instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsAssignIpv6ip,
                                AssignPrivateDnsRecord = instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsAssignPrivateDnsRecord,
                                AssignPublicIp = instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsAssignPublicIp,
                                DefinedTags = 
                                {
                                    { "Operations.CostCenter", "42" },
                                },
                                DisplayName = instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsDisplayName,
                                FreeformTags = 
                                {
                                    { "Department", "Finance" },
                                },
                                HostnameLabel = instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsHostnameLabel,
                                Ipv6addressIpv6subnetCidrPairDetails = new[]
                                {
                                    new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs
                                    {
                                        Ipv6address = instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6address,
                                        Ipv6subnetCidr = instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6subnetCidr,
                                    },
                                },
                                NsgIds = instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsNsgIds,
                                PrivateIp = instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsPrivateIp,
                                SkipSourceDestCheck = instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsSkipSourceDestCheck,
                                SubnetId = testSubnet.Id,
                            },
                            DisplayName = instanceConfigurationInstanceDetailsOptionsSecondaryVnicsDisplayName,
                            NicIndex = instanceConfigurationInstanceDetailsOptionsSecondaryVnicsNicIndex,
                        },
                    },
                },
            },
            SecondaryVnics = new[]
            {
                new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsSecondaryVnicArgs
                {
                    CreateVnicDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsArgs
                    {
                        AssignPrivateDnsRecord = instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsAssignPrivateDnsRecord,
                        AssignPublicIp = instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsAssignPublicIp,
                        DefinedTags = 
                        {
                            { "Operations.CostCenter", "42" },
                        },
                        DisplayName = instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsDisplayName,
                        FreeformTags = 
                        {
                            { "Department", "Finance" },
                        },
                        HostnameLabel = instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsHostnameLabel,
                        NsgIds = instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsNsgIds,
                        PrivateIp = instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsPrivateIp,
                        SkipSourceDestCheck = instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsSkipSourceDestCheck,
                        SubnetId = testSubnet.Id,
                    },
                    DisplayName = instanceConfigurationInstanceDetailsSecondaryVnicsDisplayName,
                    NicIndex = instanceConfigurationInstanceDetailsSecondaryVnicsNicIndex,
                },
            },
        },
        InstanceId = testInstance.Id,
        Source = instanceConfigurationSource,
    });
});
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.oci.Core.InstanceConfiguration;
import com.pulumi.oci.Core.InstanceConfigurationArgs;
import com.pulumi.oci.Core.inputs.InstanceConfigurationInstanceDetailsArgs;
import com.pulumi.oci.Core.inputs.InstanceConfigurationInstanceDetailsLaunchDetailsArgs;
import com.pulumi.oci.Core.inputs.InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigArgs;
import com.pulumi.oci.Core.inputs.InstanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigArgs;
import com.pulumi.oci.Core.inputs.InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsArgs;
import com.pulumi.oci.Core.inputs.InstanceConfigurationInstanceDetailsLaunchDetailsInstanceOptionsArgs;
import com.pulumi.oci.Core.inputs.InstanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsArgs;
import com.pulumi.oci.Core.inputs.InstanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigArgs;
import com.pulumi.oci.Core.inputs.InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigArgs;
import com.pulumi.oci.Core.inputs.InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs;
import com.pulumi.oci.Core.inputs.InstanceConfigurationInstanceDetailsLaunchDetailsShapeConfigArgs;
import com.pulumi.oci.Core.inputs.InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsArgs;
import com.pulumi.oci.Core.inputs.InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs;
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) {
        var testInstanceConfiguration = new InstanceConfiguration("testInstanceConfiguration", InstanceConfigurationArgs.builder()
            .compartmentId(compartmentId)
            .definedTags(Map.of("Operations.CostCenter", "42"))
            .displayName(instanceConfigurationDisplayName)
            .freeformTags(Map.of("Department", "Finance"))
            .instanceDetails(InstanceConfigurationInstanceDetailsArgs.builder()
                .instanceType(instanceConfigurationInstanceDetailsInstanceType)
                .blockVolumes(InstanceConfigurationInstanceDetailsBlockVolumeArgs.builder()
                    .attachDetails(InstanceConfigurationInstanceDetailsBlockVolumeAttachDetailsArgs.builder()
                        .type(instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsType)
                        .device(instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsDevice)
                        .displayName(instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsDisplayName)
                        .isPvEncryptionInTransitEnabled(instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsIsPvEncryptionInTransitEnabled)
                        .isReadOnly(instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsIsReadOnly)
                        .isShareable(instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsIsShareable)
                        .useChap(instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsUseChap)
                        .build())
                    .createDetails(InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsArgs.builder()
                        .autotunePolicies(InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsAutotunePolicyArgs.builder()
                            .autotuneType(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsAutotunePoliciesAutotuneType)
                            .maxVpusPerGb(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsAutotunePoliciesMaxVpusPerGb)
                            .build())
                        .availabilityDomain(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsAvailabilityDomain)
                        .backupPolicyId(testVolumeBackupPolicies.volumeBackupPolicies()[0].id())
                        .blockVolumeReplicas(InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsBlockVolumeReplicasArgs.builder()
                            .availabilityDomain(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsBlockVolumeReplicasAvailabilityDomain)
                            .displayName(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsBlockVolumeReplicasDisplayName)
                            .build())
                        .clusterPlacementGroupId(clusterPlacementGroupId)
                        .compartmentId(compartmentId)
                        .definedTags(Map.of("Operations.CostCenter", "42"))
                        .displayName(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsDisplayName)
                        .freeformTags(Map.of("Department", "Finance"))
                        .isAutoTuneEnabled(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsIsAutoTuneEnabled)
                        .kmsKeyId(testKey.id())
                        .sizeInGbs(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsSizeInGbs)
                        .sourceDetails(InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsSourceDetailsArgs.builder()
                            .type(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsSourceDetailsType)
                            .id(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsSourceDetailsId)
                            .build())
                        .vpusPerGb(instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsVpusPerGb)
                        .build())
                    .volumeId(testVolume.id())
                    .build())
                .launchDetails(InstanceConfigurationInstanceDetailsLaunchDetailsArgs.builder()
                    .agentConfig(InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigArgs.builder()
                        .areAllPluginsDisabled(instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigAreAllPluginsDisabled)
                        .isManagementDisabled(instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigIsManagementDisabled)
                        .isMonitoringDisabled(instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigIsMonitoringDisabled)
                        .pluginsConfigs(InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigArgs.builder()
                            .desiredState(instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigDesiredState)
                            .name(instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigName)
                            .build())
                        .build())
                    .availabilityConfig(InstanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigArgs.builder()
                        .isLiveMigrationPreferred(instanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigIsLiveMigrationPreferred)
                        .recoveryAction(instanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigRecoveryAction)
                        .build())
                    .availabilityDomain(instanceConfigurationInstanceDetailsLaunchDetailsAvailabilityDomain)
                    .capacityReservationId(testCapacityReservation.id())
                    .clusterPlacementGroupId(testGroup.id())
                    .compartmentId(compartmentId)
                    .createVnicDetails(InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsArgs.builder()
                        .assignIpv6ip(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignIpv6ip)
                        .assignPrivateDnsRecord(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignPrivateDnsRecord)
                        .assignPublicIp(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignPublicIp)
                        .definedTags(Map.of("Operations.CostCenter", "42"))
                        .displayName(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsDisplayName)
                        .freeformTags(Map.of("Department", "Finance"))
                        .hostnameLabel(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsHostnameLabel)
                        .ipv6addressIpv6subnetCidrPairDetails(InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs.builder()
                            .ipv6address(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6address)
                            .ipv6subnetCidr(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6subnetCidr)
                            .build())
                        .nsgIds(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsNsgIds)
                        .privateIp(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsPrivateIp)
                        .skipSourceDestCheck(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsSkipSourceDestCheck)
                        .subnetId(testSubnet.id())
                        .build())
                    .dedicatedVmHostId(testDedicatedVmHost.id())
                    .definedTags(Map.of("Operations.CostCenter", "42"))
                    .displayName(instanceConfigurationInstanceDetailsLaunchDetailsDisplayName)
                    .extendedMetadata(instanceConfigurationInstanceDetailsLaunchDetailsExtendedMetadata)
                    .faultDomain(instanceConfigurationInstanceDetailsLaunchDetailsFaultDomain)
                    .freeformTags(Map.of("Department", "Finance"))
                    .instanceOptions(InstanceConfigurationInstanceDetailsLaunchDetailsInstanceOptionsArgs.builder()
                        .areLegacyImdsEndpointsDisabled(instanceConfigurationInstanceDetailsLaunchDetailsInstanceOptionsAreLegacyImdsEndpointsDisabled)
                        .build())
                    .ipxeScript(instanceConfigurationInstanceDetailsLaunchDetailsIpxeScript)
                    .isPvEncryptionInTransitEnabled(instanceConfigurationInstanceDetailsLaunchDetailsIsPvEncryptionInTransitEnabled)
                    .launchMode(instanceConfigurationInstanceDetailsLaunchDetailsLaunchMode)
                    .launchOptions(InstanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsArgs.builder()
                        .bootVolumeType(instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsBootVolumeType)
                        .firmware(instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsFirmware)
                        .isConsistentVolumeNamingEnabled(instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsIsConsistentVolumeNamingEnabled)
                        .isPvEncryptionInTransitEnabled(instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsIsPvEncryptionInTransitEnabled)
                        .networkType(instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsNetworkType)
                        .remoteDataVolumeType(instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsRemoteDataVolumeType)
                        .build())
                    .metadata(instanceConfigurationInstanceDetailsLaunchDetailsMetadata)
                    .platformConfig(InstanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigArgs.builder()
                        .type(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigType)
                        .areVirtualInstructionsEnabled(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigAreVirtualInstructionsEnabled)
                        .configMap(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigConfigMap)
                        .isAccessControlServiceEnabled(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsAccessControlServiceEnabled)
                        .isInputOutputMemoryManagementUnitEnabled(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsInputOutputMemoryManagementUnitEnabled)
                        .isMeasuredBootEnabled(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsMeasuredBootEnabled)
                        .isMemoryEncryptionEnabled(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsMemoryEncryptionEnabled)
                        .isSecureBootEnabled(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsSecureBootEnabled)
                        .isSymmetricMultiThreadingEnabled(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsSymmetricMultiThreadingEnabled)
                        .isTrustedPlatformModuleEnabled(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsTrustedPlatformModuleEnabled)
                        .numaNodesPerSocket(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigNumaNodesPerSocket)
                        .percentageOfCoresEnabled(instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigPercentageOfCoresEnabled)
                        .build())
                    .preemptibleInstanceConfig(InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigArgs.builder()
                        .preemptionAction(InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs.builder()
                            .type(instanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionType)
                            .preserveBootVolume(instanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionPreserveBootVolume)
                            .build())
                        .build())
                    .preferredMaintenanceAction(instanceConfigurationInstanceDetailsLaunchDetailsPreferredMaintenanceAction)
                    .shape(instanceConfigurationInstanceDetailsLaunchDetailsShape)
                    .shapeConfig(InstanceConfigurationInstanceDetailsLaunchDetailsShapeConfigArgs.builder()
                        .baselineOcpuUtilization(instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigBaselineOcpuUtilization)
                        .memoryInGbs(instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigMemoryInGbs)
                        .nvmes(instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigNvmes)
                        .ocpus(instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigOcpus)
                        .vcpus(instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigVcpus)
                        .build())
                    .sourceDetails(InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsArgs.builder()
                        .sourceType(instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsSourceType)
                        .bootVolumeId(testBootVolume.id())
                        .bootVolumeSizeInGbs(instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsBootVolumeSizeInGbs)
                        .bootVolumeVpusPerGb(instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsBootVolumeVpusPerGb)
                        .imageId(testImage.id())
                        .kmsKeyId(testKey.id())
                        .instanceSourceImageFilterDetails(InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs.builder()
                            .compartmentId(compartmentId)
                            .definedTagsFilter(instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsDefinedTagsFilter)
                            .operatingSystem(instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystem)
                            .operatingSystemVersion(instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystemVersion)
                            .build())
                        .build())
                    .build())
                .options(InstanceConfigurationInstanceDetailsOptionArgs.builder()
                    .blockVolumes(InstanceConfigurationInstanceDetailsOptionBlockVolumeArgs.builder()
                        .attachDetails(InstanceConfigurationInstanceDetailsOptionBlockVolumeAttachDetailsArgs.builder()
                            .type(instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsType)
                            .device(instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsDevice)
                            .displayName(instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsDisplayName)
                            .isPvEncryptionInTransitEnabled(instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsIsPvEncryptionInTransitEnabled)
                            .isReadOnly(instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsIsReadOnly)
                            .isShareable(instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsIsShareable)
                            .useChap(instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsUseChap)
                            .build())
                        .createDetails(InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsArgs.builder()
                            .autotunePolicies(InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsAutotunePolicyArgs.builder()
                                .autotuneType(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsAutotunePoliciesAutotuneType)
                                .maxVpusPerGb(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsAutotunePoliciesMaxVpusPerGb)
                                .build())
                            .availabilityDomain(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsAvailabilityDomain)
                            .backupPolicyId(testVolumeBackupPolicies.volumeBackupPolicies()[0].id())
                            .clusterPlacementGroupId(clusterPlacementGroupId)
                            .compartmentId(compartmentId)
                            .definedTags(Map.of("Operations.CostCenter", "42"))
                            .displayName(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsDisplayName)
                            .freeformTags(Map.of("Department", "Finance"))
                            .kmsKeyId(testKey.id())
                            .sizeInGbs(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsSizeInGbs)
                            .sourceDetails(InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsSourceDetailsArgs.builder()
                                .type(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsSourceDetailsType)
                                .id(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsSourceDetailsId)
                                .build())
                            .vpusPerGb(instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsVpusPerGb)
                            .build())
                        .volumeId(testVolume.id())
                        .build())
                    .launchDetails(InstanceConfigurationInstanceDetailsOptionLaunchDetailsArgs.builder()
                        .agentConfig(InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigArgs.builder()
                            .areAllPluginsDisabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigAreAllPluginsDisabled)
                            .isManagementDisabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigIsManagementDisabled)
                            .isMonitoringDisabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigIsMonitoringDisabled)
                            .pluginsConfigs(InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigPluginsConfigArgs.builder()
                                .desiredState(instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigPluginsConfigDesiredState)
                                .name(instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigPluginsConfigName)
                                .build())
                            .build())
                        .availabilityConfig(InstanceConfigurationInstanceDetailsOptionLaunchDetailsAvailabilityConfigArgs.builder()
                            .recoveryAction(instanceConfigurationInstanceDetailsOptionsLaunchDetailsAvailabilityConfigRecoveryAction)
                            .build())
                        .availabilityDomain(instanceConfigurationInstanceDetailsOptionsLaunchDetailsAvailabilityDomain)
                        .capacityReservationId(testCapacityReservation.id())
                        .clusterPlacementGroupId(testGroup.id())
                        .compartmentId(compartmentId)
                        .createVnicDetails(InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsArgs.builder()
                            .assignIpv6ip(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignIpv6ip)
                            .assignPrivateDnsRecord(instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsAssignPrivateDnsRecord)
                            .assignPublicIp(instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsAssignPublicIp)
                            .definedTags(Map.of("Operations.CostCenter", "42"))
                            .displayName(instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsDisplayName)
                            .freeformTags(Map.of("Department", "Finance"))
                            .hostnameLabel(instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsHostnameLabel)
                            .ipv6addressIpv6subnetCidrPairDetails(InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs.builder()
                                .ipv6address(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6address)
                                .ipv6subnetCidr(instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6subnetCidr)
                                .build())
                            .nsgIds(instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsNsgIds)
                            .privateIp(instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsPrivateIp)
                            .skipSourceDestCheck(instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsSkipSourceDestCheck)
                            .subnetId(testSubnet.id())
                            .build())
                        .dedicatedVmHostId(testDedicatedVmHost.id())
                        .definedTags(Map.of("Operations.CostCenter", "42"))
                        .displayName(instanceConfigurationInstanceDetailsOptionsLaunchDetailsDisplayName)
                        .extendedMetadata(instanceConfigurationInstanceDetailsOptionsLaunchDetailsExtendedMetadata)
                        .faultDomain(instanceConfigurationInstanceDetailsOptionsLaunchDetailsFaultDomain)
                        .freeformTags(Map.of("Department", "Finance"))
                        .instanceOptions(InstanceConfigurationInstanceDetailsOptionLaunchDetailsInstanceOptionsArgs.builder()
                            .areLegacyImdsEndpointsDisabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsInstanceOptionsAreLegacyImdsEndpointsDisabled)
                            .build())
                        .ipxeScript(instanceConfigurationInstanceDetailsOptionsLaunchDetailsIpxeScript)
                        .isPvEncryptionInTransitEnabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsIsPvEncryptionInTransitEnabled)
                        .launchMode(instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchMode)
                        .launchOptions(InstanceConfigurationInstanceDetailsOptionLaunchDetailsLaunchOptionsArgs.builder()
                            .bootVolumeType(instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsBootVolumeType)
                            .firmware(instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsFirmware)
                            .isConsistentVolumeNamingEnabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsIsConsistentVolumeNamingEnabled)
                            .isPvEncryptionInTransitEnabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsIsPvEncryptionInTransitEnabled)
                            .networkType(instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsNetworkType)
                            .remoteDataVolumeType(instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsRemoteDataVolumeType)
                            .build())
                        .metadata(instanceConfigurationInstanceDetailsOptionsLaunchDetailsMetadata)
                        .platformConfig(InstanceConfigurationInstanceDetailsOptionLaunchDetailsPlatformConfigArgs.builder()
                            .type(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigType)
                            .areVirtualInstructionsEnabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigAreVirtualInstructionsEnabled)
                            .isAccessControlServiceEnabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsAccessControlServiceEnabled)
                            .isInputOutputMemoryManagementUnitEnabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsInputOutputMemoryManagementUnitEnabled)
                            .isMeasuredBootEnabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsMeasuredBootEnabled)
                            .isMemoryEncryptionEnabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsMemoryEncryptionEnabled)
                            .isSecureBootEnabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsSecureBootEnabled)
                            .isSymmetricMultiThreadingEnabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsSymmetricMultiThreadingEnabled)
                            .isTrustedPlatformModuleEnabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsTrustedPlatformModuleEnabled)
                            .numaNodesPerSocket(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigNumaNodesPerSocket)
                            .percentageOfCoresEnabled(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigPercentageOfCoresEnabled)
                            .build())
                        .preemptibleInstanceConfig(InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigArgs.builder()
                            .preemptionAction(InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs.builder()
                                .type(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPreemptibleInstanceConfigPreemptionActionType)
                                .preserveBootVolume(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPreemptibleInstanceConfigPreemptionActionPreserveBootVolume)
                                .build())
                            .build())
                        .preferredMaintenanceAction(instanceConfigurationInstanceDetailsOptionsLaunchDetailsPreferredMaintenanceAction)
                        .shape(instanceConfigurationInstanceDetailsOptionsLaunchDetailsShape)
                        .shapeConfig(InstanceConfigurationInstanceDetailsOptionLaunchDetailsShapeConfigArgs.builder()
                            .baselineOcpuUtilization(instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigBaselineOcpuUtilization)
                            .memoryInGbs(instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigMemoryInGbs)
                            .nvmes(instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigNvmes)
                            .ocpus(instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigOcpus)
                            .vcpus(instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigVcpus)
                            .build())
                        .sourceDetails(InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsArgs.builder()
                            .sourceType(instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsSourceType)
                            .bootVolumeId(testBootVolume.id())
                            .bootVolumeSizeInGbs(instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsBootVolumeSizeInGbs)
                            .bootVolumeVpusPerGb(instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsBootVolumeVpusPerGb)
                            .imageId(testImage.id())
                            .instanceSourceImageFilterDetails(InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs.builder()
                                .compartmentId(compartmentId)
                                .definedTagsFilter(instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsDefinedTagsFilter)
                                .operatingSystem(instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystem)
                                .operatingSystemVersion(instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystemVersion)
                                .build())
                            .build())
                        .build())
                    .secondaryVnics(InstanceConfigurationInstanceDetailsOptionSecondaryVnicArgs.builder()
                        .createVnicDetails(InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsArgs.builder()
                            .assignIpv6ip(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsAssignIpv6ip)
                            .assignPrivateDnsRecord(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsAssignPrivateDnsRecord)
                            .assignPublicIp(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsAssignPublicIp)
                            .definedTags(Map.of("Operations.CostCenter", "42"))
                            .displayName(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsDisplayName)
                            .freeformTags(Map.of("Department", "Finance"))
                            .hostnameLabel(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsHostnameLabel)
                            .ipv6addressIpv6subnetCidrPairDetails(InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs.builder()
                                .ipv6address(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6address)
                                .ipv6subnetCidr(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6subnetCidr)
                                .build())
                            .nsgIds(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsNsgIds)
                            .privateIp(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsPrivateIp)
                            .skipSourceDestCheck(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsSkipSourceDestCheck)
                            .subnetId(testSubnet.id())
                            .build())
                        .displayName(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsDisplayName)
                        .nicIndex(instanceConfigurationInstanceDetailsOptionsSecondaryVnicsNicIndex)
                        .build())
                    .build())
                .secondaryVnics(InstanceConfigurationInstanceDetailsSecondaryVnicArgs.builder()
                    .createVnicDetails(InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsArgs.builder()
                        .assignPrivateDnsRecord(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsAssignPrivateDnsRecord)
                        .assignPublicIp(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsAssignPublicIp)
                        .definedTags(Map.of("Operations.CostCenter", "42"))
                        .displayName(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsDisplayName)
                        .freeformTags(Map.of("Department", "Finance"))
                        .hostnameLabel(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsHostnameLabel)
                        .nsgIds(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsNsgIds)
                        .privateIp(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsPrivateIp)
                        .skipSourceDestCheck(instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsSkipSourceDestCheck)
                        .subnetId(testSubnet.id())
                        .build())
                    .displayName(instanceConfigurationInstanceDetailsSecondaryVnicsDisplayName)
                    .nicIndex(instanceConfigurationInstanceDetailsSecondaryVnicsNicIndex)
                    .build())
                .build())
            .instanceId(testInstance.id())
            .source(instanceConfigurationSource)
            .build());
    }
}
resources:
  testInstanceConfiguration:
    type: oci:Core:InstanceConfiguration
    name: test_instance_configuration
    properties:
      compartmentId: ${compartmentId}
      definedTags:
        Operations.CostCenter: '42'
      displayName: ${instanceConfigurationDisplayName}
      freeformTags:
        Department: Finance
      instanceDetails:
        instanceType: ${instanceConfigurationInstanceDetailsInstanceType}
        blockVolumes:
          - attachDetails:
              type: ${instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsType}
              device: ${instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsDevice}
              displayName: ${instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsDisplayName}
              isPvEncryptionInTransitEnabled: ${instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsIsPvEncryptionInTransitEnabled}
              isReadOnly: ${instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsIsReadOnly}
              isShareable: ${instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsIsShareable}
              useChap: ${instanceConfigurationInstanceDetailsBlockVolumesAttachDetailsUseChap}
            createDetails:
              autotunePolicies:
                - autotuneType: ${instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsAutotunePoliciesAutotuneType}
                  maxVpusPerGb: ${instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsAutotunePoliciesMaxVpusPerGb}
              availabilityDomain: ${instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsAvailabilityDomain}
              backupPolicyId: ${testVolumeBackupPolicies.volumeBackupPolicies[0].id}
              blockVolumeReplicas:
                availabilityDomain: ${instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsBlockVolumeReplicasAvailabilityDomain}
                displayName: ${instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsBlockVolumeReplicasDisplayName}
              clusterPlacementGroupId: ${clusterPlacementGroupId}
              compartmentId: ${compartmentId}
              definedTags:
                Operations.CostCenter: '42'
              displayName: ${instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsDisplayName}
              freeformTags:
                Department: Finance
              isAutoTuneEnabled: ${instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsIsAutoTuneEnabled}
              kmsKeyId: ${testKey.id}
              sizeInGbs: ${instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsSizeInGbs}
              sourceDetails:
                type: ${instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsSourceDetailsType}
                id: ${instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsSourceDetailsId}
              vpusPerGb: ${instanceConfigurationInstanceDetailsBlockVolumesCreateDetailsVpusPerGb}
            volumeId: ${testVolume.id}
        launchDetails:
          agentConfig:
            areAllPluginsDisabled: ${instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigAreAllPluginsDisabled}
            isManagementDisabled: ${instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigIsManagementDisabled}
            isMonitoringDisabled: ${instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigIsMonitoringDisabled}
            pluginsConfigs:
              - desiredState: ${instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigDesiredState}
                name: ${instanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigName}
          availabilityConfig:
            isLiveMigrationPreferred: ${instanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigIsLiveMigrationPreferred}
            recoveryAction: ${instanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigRecoveryAction}
          availabilityDomain: ${instanceConfigurationInstanceDetailsLaunchDetailsAvailabilityDomain}
          capacityReservationId: ${testCapacityReservation.id}
          clusterPlacementGroupId: ${testGroup.id}
          compartmentId: ${compartmentId}
          createVnicDetails:
            assignIpv6ip: ${instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignIpv6ip}
            assignPrivateDnsRecord: ${instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignPrivateDnsRecord}
            assignPublicIp: ${instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignPublicIp}
            definedTags:
              Operations.CostCenter: '42'
            displayName: ${instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsDisplayName}
            freeformTags:
              Department: Finance
            hostnameLabel: ${instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsHostnameLabel}
            ipv6addressIpv6subnetCidrPairDetails:
              - ipv6address: ${instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6address}
                ipv6subnetCidr: ${instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6subnetCidr}
            nsgIds: ${instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsNsgIds}
            privateIp: ${instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsPrivateIp}
            skipSourceDestCheck: ${instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsSkipSourceDestCheck}
            subnetId: ${testSubnet.id}
          dedicatedVmHostId: ${testDedicatedVmHost.id}
          definedTags:
            Operations.CostCenter: '42'
          displayName: ${instanceConfigurationInstanceDetailsLaunchDetailsDisplayName}
          extendedMetadata: ${instanceConfigurationInstanceDetailsLaunchDetailsExtendedMetadata}
          faultDomain: ${instanceConfigurationInstanceDetailsLaunchDetailsFaultDomain}
          freeformTags:
            Department: Finance
          instanceOptions:
            areLegacyImdsEndpointsDisabled: ${instanceConfigurationInstanceDetailsLaunchDetailsInstanceOptionsAreLegacyImdsEndpointsDisabled}
          ipxeScript: ${instanceConfigurationInstanceDetailsLaunchDetailsIpxeScript}
          isPvEncryptionInTransitEnabled: ${instanceConfigurationInstanceDetailsLaunchDetailsIsPvEncryptionInTransitEnabled}
          launchMode: ${instanceConfigurationInstanceDetailsLaunchDetailsLaunchMode}
          launchOptions:
            bootVolumeType: ${instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsBootVolumeType}
            firmware: ${instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsFirmware}
            isConsistentVolumeNamingEnabled: ${instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsIsConsistentVolumeNamingEnabled}
            isPvEncryptionInTransitEnabled: ${instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsIsPvEncryptionInTransitEnabled}
            networkType: ${instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsNetworkType}
            remoteDataVolumeType: ${instanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsRemoteDataVolumeType}
          metadata: ${instanceConfigurationInstanceDetailsLaunchDetailsMetadata}
          platformConfig:
            type: ${instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigType}
            areVirtualInstructionsEnabled: ${instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigAreVirtualInstructionsEnabled}
            configMap: ${instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigConfigMap}
            isAccessControlServiceEnabled: ${instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsAccessControlServiceEnabled}
            isInputOutputMemoryManagementUnitEnabled: ${instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsInputOutputMemoryManagementUnitEnabled}
            isMeasuredBootEnabled: ${instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsMeasuredBootEnabled}
            isMemoryEncryptionEnabled: ${instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsMemoryEncryptionEnabled}
            isSecureBootEnabled: ${instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsSecureBootEnabled}
            isSymmetricMultiThreadingEnabled: ${instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsSymmetricMultiThreadingEnabled}
            isTrustedPlatformModuleEnabled: ${instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigIsTrustedPlatformModuleEnabled}
            numaNodesPerSocket: ${instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigNumaNodesPerSocket}
            percentageOfCoresEnabled: ${instanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigPercentageOfCoresEnabled}
          preemptibleInstanceConfig:
            preemptionAction:
              type: ${instanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionType}
              preserveBootVolume: ${instanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionPreserveBootVolume}
          preferredMaintenanceAction: ${instanceConfigurationInstanceDetailsLaunchDetailsPreferredMaintenanceAction}
          shape: ${instanceConfigurationInstanceDetailsLaunchDetailsShape}
          shapeConfig:
            baselineOcpuUtilization: ${instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigBaselineOcpuUtilization}
            memoryInGbs: ${instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigMemoryInGbs}
            nvmes: ${instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigNvmes}
            ocpus: ${instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigOcpus}
            vcpus: ${instanceConfigurationInstanceDetailsLaunchDetailsShapeConfigVcpus}
          sourceDetails:
            sourceType: ${instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsSourceType}
            bootVolumeId: ${testBootVolume.id}
            bootVolumeSizeInGbs: ${instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsBootVolumeSizeInGbs}
            bootVolumeVpusPerGb: ${instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsBootVolumeVpusPerGb}
            imageId: ${testImage.id}
            kmsKeyId: ${testKey.id}
            instanceSourceImageFilterDetails:
              compartmentId: ${compartmentId}
              definedTagsFilter: ${instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsDefinedTagsFilter}
              operatingSystem: ${instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystem}
              operatingSystemVersion: ${instanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystemVersion}
        options:
          - blockVolumes:
              - attachDetails:
                  type: ${instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsType}
                  device: ${instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsDevice}
                  displayName: ${instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsDisplayName}
                  isPvEncryptionInTransitEnabled: ${instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsIsPvEncryptionInTransitEnabled}
                  isReadOnly: ${instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsIsReadOnly}
                  isShareable: ${instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsIsShareable}
                  useChap: ${instanceConfigurationInstanceDetailsOptionsBlockVolumesAttachDetailsUseChap}
                createDetails:
                  autotunePolicies:
                    - autotuneType: ${instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsAutotunePoliciesAutotuneType}
                      maxVpusPerGb: ${instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsAutotunePoliciesMaxVpusPerGb}
                  availabilityDomain: ${instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsAvailabilityDomain}
                  backupPolicyId: ${testVolumeBackupPolicies.volumeBackupPolicies[0].id}
                  clusterPlacementGroupId: ${clusterPlacementGroupId}
                  compartmentId: ${compartmentId}
                  definedTags:
                    Operations.CostCenter: '42'
                  displayName: ${instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsDisplayName}
                  freeformTags:
                    Department: Finance
                  kmsKeyId: ${testKey.id}
                  sizeInGbs: ${instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsSizeInGbs}
                  sourceDetails:
                    type: ${instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsSourceDetailsType}
                    id: ${instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsSourceDetailsId}
                  vpusPerGb: ${instanceConfigurationInstanceDetailsOptionsBlockVolumesCreateDetailsVpusPerGb}
                volumeId: ${testVolume.id}
            launchDetails:
              agentConfig:
                areAllPluginsDisabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigAreAllPluginsDisabled}
                isManagementDisabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigIsManagementDisabled}
                isMonitoringDisabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigIsMonitoringDisabled}
                pluginsConfigs:
                  - desiredState: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigPluginsConfigDesiredState}
                    name: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsAgentConfigPluginsConfigName}
              availabilityConfig:
                recoveryAction: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsAvailabilityConfigRecoveryAction}
              availabilityDomain: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsAvailabilityDomain}
              capacityReservationId: ${testCapacityReservation.id}
              clusterPlacementGroupId: ${testGroup.id}
              compartmentId: ${compartmentId}
              createVnicDetails:
                assignIpv6ip: ${instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsAssignIpv6ip}
                assignPrivateDnsRecord: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsAssignPrivateDnsRecord}
                assignPublicIp: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsAssignPublicIp}
                definedTags:
                  Operations.CostCenter: '42'
                displayName: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsDisplayName}
                freeformTags:
                  Department: Finance
                hostnameLabel: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsHostnameLabel}
                ipv6addressIpv6subnetCidrPairDetails:
                  - ipv6address: ${instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6address}
                    ipv6subnetCidr: ${instanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6subnetCidr}
                nsgIds: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsNsgIds}
                privateIp: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsPrivateIp}
                skipSourceDestCheck: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsCreateVnicDetailsSkipSourceDestCheck}
                subnetId: ${testSubnet.id}
              dedicatedVmHostId: ${testDedicatedVmHost.id}
              definedTags:
                Operations.CostCenter: '42'
              displayName: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsDisplayName}
              extendedMetadata: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsExtendedMetadata}
              faultDomain: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsFaultDomain}
              freeformTags:
                Department: Finance
              instanceOptions:
                areLegacyImdsEndpointsDisabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsInstanceOptionsAreLegacyImdsEndpointsDisabled}
              ipxeScript: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsIpxeScript}
              isPvEncryptionInTransitEnabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsIsPvEncryptionInTransitEnabled}
              launchMode: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchMode}
              launchOptions:
                bootVolumeType: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsBootVolumeType}
                firmware: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsFirmware}
                isConsistentVolumeNamingEnabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsIsConsistentVolumeNamingEnabled}
                isPvEncryptionInTransitEnabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsIsPvEncryptionInTransitEnabled}
                networkType: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsNetworkType}
                remoteDataVolumeType: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsLaunchOptionsRemoteDataVolumeType}
              metadata: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsMetadata}
              platformConfig:
                type: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigType}
                areVirtualInstructionsEnabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigAreVirtualInstructionsEnabled}
                isAccessControlServiceEnabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsAccessControlServiceEnabled}
                isInputOutputMemoryManagementUnitEnabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsInputOutputMemoryManagementUnitEnabled}
                isMeasuredBootEnabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsMeasuredBootEnabled}
                isMemoryEncryptionEnabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsMemoryEncryptionEnabled}
                isSecureBootEnabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsSecureBootEnabled}
                isSymmetricMultiThreadingEnabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsSymmetricMultiThreadingEnabled}
                isTrustedPlatformModuleEnabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigIsTrustedPlatformModuleEnabled}
                numaNodesPerSocket: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigNumaNodesPerSocket}
                percentageOfCoresEnabled: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsPlatformConfigPercentageOfCoresEnabled}
              preemptibleInstanceConfig:
                preemptionAction:
                  type: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsPreemptibleInstanceConfigPreemptionActionType}
                  preserveBootVolume: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsPreemptibleInstanceConfigPreemptionActionPreserveBootVolume}
              preferredMaintenanceAction: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsPreferredMaintenanceAction}
              shape: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsShape}
              shapeConfig:
                baselineOcpuUtilization: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigBaselineOcpuUtilization}
                memoryInGbs: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigMemoryInGbs}
                nvmes: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigNvmes}
                ocpus: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigOcpus}
                vcpus: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsShapeConfigVcpus}
              sourceDetails:
                sourceType: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsSourceType}
                bootVolumeId: ${testBootVolume.id}
                bootVolumeSizeInGbs: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsBootVolumeSizeInGbs}
                bootVolumeVpusPerGb: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsBootVolumeVpusPerGb}
                imageId: ${testImage.id}
                instanceSourceImageFilterDetails:
                  compartmentId: ${compartmentId}
                  definedTagsFilter: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsDefinedTagsFilter}
                  operatingSystem: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystem}
                  operatingSystemVersion: ${instanceConfigurationInstanceDetailsOptionsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsOperatingSystemVersion}
            secondaryVnics:
              - createVnicDetails:
                  assignIpv6ip: ${instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsAssignIpv6ip}
                  assignPrivateDnsRecord: ${instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsAssignPrivateDnsRecord}
                  assignPublicIp: ${instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsAssignPublicIp}
                  definedTags:
                    Operations.CostCenter: '42'
                  displayName: ${instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsDisplayName}
                  freeformTags:
                    Department: Finance
                  hostnameLabel: ${instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsHostnameLabel}
                  ipv6addressIpv6subnetCidrPairDetails:
                    - ipv6address: ${instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6address}
                      ipv6subnetCidr: ${instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailsIpv6subnetCidr}
                  nsgIds: ${instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsNsgIds}
                  privateIp: ${instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsPrivateIp}
                  skipSourceDestCheck: ${instanceConfigurationInstanceDetailsOptionsSecondaryVnicsCreateVnicDetailsSkipSourceDestCheck}
                  subnetId: ${testSubnet.id}
                displayName: ${instanceConfigurationInstanceDetailsOptionsSecondaryVnicsDisplayName}
                nicIndex: ${instanceConfigurationInstanceDetailsOptionsSecondaryVnicsNicIndex}
        secondaryVnics:
          - createVnicDetails:
              assignPrivateDnsRecord: ${instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsAssignPrivateDnsRecord}
              assignPublicIp: ${instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsAssignPublicIp}
              definedTags:
                Operations.CostCenter: '42'
              displayName: ${instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsDisplayName}
              freeformTags:
                Department: Finance
              hostnameLabel: ${instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsHostnameLabel}
              nsgIds: ${instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsNsgIds}
              privateIp: ${instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsPrivateIp}
              skipSourceDestCheck: ${instanceConfigurationInstanceDetailsSecondaryVnicsCreateVnicDetailsSkipSourceDestCheck}
              subnetId: ${testSubnet.id}
            displayName: ${instanceConfigurationInstanceDetailsSecondaryVnicsDisplayName}
            nicIndex: ${instanceConfigurationInstanceDetailsSecondaryVnicsNicIndex}
      instanceId: ${testInstance.id}
      source: ${instanceConfigurationSource}
Create InstanceConfiguration Resource
Resources are created with functions called constructors. To learn more about declaring and configuring resources, see Resources.
Constructor syntax
new InstanceConfiguration(name: string, args: InstanceConfigurationArgs, opts?: CustomResourceOptions);@overload
def InstanceConfiguration(resource_name: str,
                          args: InstanceConfigurationArgs,
                          opts: Optional[ResourceOptions] = None)
@overload
def InstanceConfiguration(resource_name: str,
                          opts: Optional[ResourceOptions] = None,
                          compartment_id: Optional[str] = None,
                          defined_tags: Optional[Mapping[str, Any]] = None,
                          display_name: Optional[str] = None,
                          freeform_tags: Optional[Mapping[str, Any]] = None,
                          instance_details: Optional[_core.InstanceConfigurationInstanceDetailsArgs] = None,
                          instance_id: Optional[str] = None,
                          source: Optional[str] = None)func NewInstanceConfiguration(ctx *Context, name string, args InstanceConfigurationArgs, opts ...ResourceOption) (*InstanceConfiguration, error)public InstanceConfiguration(string name, InstanceConfigurationArgs args, CustomResourceOptions? opts = null)
public InstanceConfiguration(String name, InstanceConfigurationArgs args)
public InstanceConfiguration(String name, InstanceConfigurationArgs args, CustomResourceOptions options)
type: oci:Core:InstanceConfiguration
properties: # The arguments to resource properties.
options: # Bag of options to control resource's behavior.
Parameters
- name string
- The unique name of the resource.
- args InstanceConfigurationArgs
- The arguments to resource properties.
- opts CustomResourceOptions
- Bag of options to control resource's behavior.
- resource_name str
- The unique name of the resource.
- args InstanceConfigurationArgs
- The arguments to resource properties.
- opts ResourceOptions
- Bag of options to control resource's behavior.
- ctx Context
- Context object for the current deployment.
- name string
- The unique name of the resource.
- args InstanceConfigurationArgs
- The arguments to resource properties.
- opts ResourceOption
- Bag of options to control resource's behavior.
- name string
- The unique name of the resource.
- args InstanceConfigurationArgs
- The arguments to resource properties.
- opts CustomResourceOptions
- Bag of options to control resource's behavior.
- name String
- The unique name of the resource.
- args InstanceConfigurationArgs
- The arguments to resource properties.
- options CustomResourceOptions
- Bag of options to control resource's behavior.
Constructor example
The following reference example uses placeholder values for all input properties.
var instanceConfigurationResource = new Oci.Core.InstanceConfiguration("instanceConfigurationResource", new()
{
    CompartmentId = "string",
    DefinedTags = 
    {
        { "string", "any" },
    },
    DisplayName = "string",
    FreeformTags = 
    {
        { "string", "any" },
    },
    InstanceDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsArgs
    {
        InstanceType = "string",
        BlockVolumes = new[]
        {
            new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsBlockVolumeArgs
            {
                AttachDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsBlockVolumeAttachDetailsArgs
                {
                    Type = "string",
                    Device = "string",
                    DisplayName = "string",
                    IsPvEncryptionInTransitEnabled = false,
                    IsReadOnly = false,
                    IsShareable = false,
                    UseChap = false,
                },
                CreateDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsArgs
                {
                    AutotunePolicies = new[]
                    {
                        new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsAutotunePolicyArgs
                        {
                            AutotuneType = "string",
                            MaxVpusPerGb = "string",
                        },
                    },
                    AvailabilityDomain = "string",
                    BackupPolicyId = "string",
                    BlockVolumeReplicas = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsBlockVolumeReplicasArgs
                    {
                        AvailabilityDomain = "string",
                        DisplayName = "string",
                    },
                    ClusterPlacementGroupId = "string",
                    CompartmentId = "string",
                    DefinedTags = 
                    {
                        { "string", "any" },
                    },
                    DisplayName = "string",
                    FreeformTags = 
                    {
                        { "string", "any" },
                    },
                    IsAutoTuneEnabled = false,
                    KmsKeyId = "string",
                    SizeInGbs = "string",
                    SourceDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsSourceDetailsArgs
                    {
                        Type = "string",
                        Id = "string",
                    },
                    VpusPerGb = "string",
                },
                VolumeId = "string",
            },
        },
        LaunchDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsArgs
        {
            AgentConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigArgs
            {
                AreAllPluginsDisabled = false,
                IsManagementDisabled = false,
                IsMonitoringDisabled = false,
                PluginsConfigs = new[]
                {
                    new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigArgs
                    {
                        DesiredState = "string",
                        Name = "string",
                    },
                },
            },
            AvailabilityConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigArgs
            {
                IsLiveMigrationPreferred = false,
                RecoveryAction = "string",
            },
            AvailabilityDomain = "string",
            CapacityReservationId = "string",
            ClusterPlacementGroupId = "string",
            CompartmentId = "string",
            CreateVnicDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsArgs
            {
                AssignIpv6ip = false,
                AssignPrivateDnsRecord = false,
                AssignPublicIp = false,
                DefinedTags = 
                {
                    { "string", "any" },
                },
                DisplayName = "string",
                FreeformTags = 
                {
                    { "string", "any" },
                },
                HostnameLabel = "string",
                Ipv6addressIpv6subnetCidrPairDetails = new[]
                {
                    new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs
                    {
                        Ipv6address = "string",
                        Ipv6subnetCidr = "string",
                    },
                },
                NsgIds = new[]
                {
                    "string",
                },
                PrivateIp = "string",
                SkipSourceDestCheck = false,
                SubnetId = "string",
            },
            DedicatedVmHostId = "string",
            DefinedTags = 
            {
                { "string", "any" },
            },
            DisplayName = "string",
            ExtendedMetadata = 
            {
                { "string", "any" },
            },
            FaultDomain = "string",
            FreeformTags = 
            {
                { "string", "any" },
            },
            InstanceOptions = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsInstanceOptionsArgs
            {
                AreLegacyImdsEndpointsDisabled = false,
            },
            IpxeScript = "string",
            IsPvEncryptionInTransitEnabled = false,
            LaunchMode = "string",
            LaunchOptions = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsArgs
            {
                BootVolumeType = "string",
                Firmware = "string",
                IsConsistentVolumeNamingEnabled = false,
                IsPvEncryptionInTransitEnabled = false,
                NetworkType = "string",
                RemoteDataVolumeType = "string",
            },
            Metadata = 
            {
                { "string", "any" },
            },
            PlatformConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigArgs
            {
                Type = "string",
                AreVirtualInstructionsEnabled = false,
                ConfigMap = 
                {
                    { "string", "any" },
                },
                IsAccessControlServiceEnabled = false,
                IsInputOutputMemoryManagementUnitEnabled = false,
                IsMeasuredBootEnabled = false,
                IsMemoryEncryptionEnabled = false,
                IsSecureBootEnabled = false,
                IsSymmetricMultiThreadingEnabled = false,
                IsTrustedPlatformModuleEnabled = false,
                NumaNodesPerSocket = "string",
                PercentageOfCoresEnabled = 0,
            },
            PreemptibleInstanceConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigArgs
            {
                PreemptionAction = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs
                {
                    Type = "string",
                    PreserveBootVolume = false,
                },
            },
            PreferredMaintenanceAction = "string",
            Shape = "string",
            ShapeConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsShapeConfigArgs
            {
                BaselineOcpuUtilization = "string",
                MemoryInGbs = 0,
                Nvmes = 0,
                Ocpus = 0,
                Vcpus = 0,
            },
            SourceDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsArgs
            {
                SourceType = "string",
                BootVolumeId = "string",
                BootVolumeSizeInGbs = "string",
                BootVolumeVpusPerGb = "string",
                ImageId = "string",
                InstanceSourceImageFilterDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs
                {
                    CompartmentId = "string",
                    DefinedTagsFilter = 
                    {
                        { "string", "any" },
                    },
                    OperatingSystem = "string",
                    OperatingSystemVersion = "string",
                },
                KmsKeyId = "string",
            },
        },
        Options = new[]
        {
            new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionArgs
            {
                BlockVolumes = new[]
                {
                    new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionBlockVolumeArgs
                    {
                        AttachDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionBlockVolumeAttachDetailsArgs
                        {
                            Type = "string",
                            Device = "string",
                            DisplayName = "string",
                            IsPvEncryptionInTransitEnabled = false,
                            IsReadOnly = false,
                            IsShareable = false,
                            UseChap = false,
                        },
                        CreateDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsArgs
                        {
                            AutotunePolicies = new[]
                            {
                                new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsAutotunePolicyArgs
                                {
                                    AutotuneType = "string",
                                    MaxVpusPerGb = "string",
                                },
                            },
                            AvailabilityDomain = "string",
                            BackupPolicyId = "string",
                            BlockVolumeReplicas = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsBlockVolumeReplicasArgs
                            {
                                AvailabilityDomain = "string",
                                DisplayName = "string",
                            },
                            ClusterPlacementGroupId = "string",
                            CompartmentId = "string",
                            DefinedTags = 
                            {
                                { "string", "any" },
                            },
                            DisplayName = "string",
                            FreeformTags = 
                            {
                                { "string", "any" },
                            },
                            IsAutoTuneEnabled = false,
                            KmsKeyId = "string",
                            SizeInGbs = "string",
                            SourceDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsSourceDetailsArgs
                            {
                                Type = "string",
                                Id = "string",
                            },
                            VpusPerGb = "string",
                        },
                        VolumeId = "string",
                    },
                },
                LaunchDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsArgs
                {
                    AgentConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigArgs
                    {
                        AreAllPluginsDisabled = false,
                        IsManagementDisabled = false,
                        IsMonitoringDisabled = false,
                        PluginsConfigs = new[]
                        {
                            new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigPluginsConfigArgs
                            {
                                DesiredState = "string",
                                Name = "string",
                            },
                        },
                    },
                    AvailabilityConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAvailabilityConfigArgs
                    {
                        IsLiveMigrationPreferred = false,
                        RecoveryAction = "string",
                    },
                    AvailabilityDomain = "string",
                    CapacityReservationId = "string",
                    ClusterPlacementGroupId = "string",
                    CompartmentId = "string",
                    CreateVnicDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsArgs
                    {
                        AssignIpv6ip = false,
                        AssignPrivateDnsRecord = false,
                        AssignPublicIp = false,
                        DefinedTags = 
                        {
                            { "string", "any" },
                        },
                        DisplayName = "string",
                        FreeformTags = 
                        {
                            { "string", "any" },
                        },
                        HostnameLabel = "string",
                        Ipv6addressIpv6subnetCidrPairDetails = new[]
                        {
                            new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs
                            {
                                Ipv6address = "string",
                                Ipv6subnetCidr = "string",
                            },
                        },
                        NsgIds = new[]
                        {
                            "string",
                        },
                        PrivateIp = "string",
                        SkipSourceDestCheck = false,
                        SubnetId = "string",
                    },
                    DedicatedVmHostId = "string",
                    DefinedTags = 
                    {
                        { "string", "any" },
                    },
                    DisplayName = "string",
                    ExtendedMetadata = 
                    {
                        { "string", "any" },
                    },
                    FaultDomain = "string",
                    FreeformTags = 
                    {
                        { "string", "any" },
                    },
                    InstanceOptions = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsInstanceOptionsArgs
                    {
                        AreLegacyImdsEndpointsDisabled = false,
                    },
                    IpxeScript = "string",
                    IsPvEncryptionInTransitEnabled = false,
                    LaunchMode = "string",
                    LaunchOptions = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsLaunchOptionsArgs
                    {
                        BootVolumeType = "string",
                        Firmware = "string",
                        IsConsistentVolumeNamingEnabled = false,
                        IsPvEncryptionInTransitEnabled = false,
                        NetworkType = "string",
                        RemoteDataVolumeType = "string",
                    },
                    Metadata = 
                    {
                        { "string", "any" },
                    },
                    PlatformConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPlatformConfigArgs
                    {
                        Type = "string",
                        AreVirtualInstructionsEnabled = false,
                        IsAccessControlServiceEnabled = false,
                        IsInputOutputMemoryManagementUnitEnabled = false,
                        IsMeasuredBootEnabled = false,
                        IsMemoryEncryptionEnabled = false,
                        IsSecureBootEnabled = false,
                        IsSymmetricMultiThreadingEnabled = false,
                        IsTrustedPlatformModuleEnabled = false,
                        NumaNodesPerSocket = "string",
                        PercentageOfCoresEnabled = 0,
                    },
                    PreemptibleInstanceConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigArgs
                    {
                        PreemptionAction = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs
                        {
                            Type = "string",
                            PreserveBootVolume = false,
                        },
                    },
                    PreferredMaintenanceAction = "string",
                    Shape = "string",
                    ShapeConfig = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsShapeConfigArgs
                    {
                        BaselineOcpuUtilization = "string",
                        MemoryInGbs = 0,
                        Nvmes = 0,
                        Ocpus = 0,
                        Vcpus = 0,
                    },
                    SourceDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsArgs
                    {
                        SourceType = "string",
                        BootVolumeId = "string",
                        BootVolumeSizeInGbs = "string",
                        BootVolumeVpusPerGb = "string",
                        ImageId = "string",
                        InstanceSourceImageFilterDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs
                        {
                            CompartmentId = "string",
                            DefinedTagsFilter = 
                            {
                                { "string", "any" },
                            },
                            OperatingSystem = "string",
                            OperatingSystemVersion = "string",
                        },
                        KmsKeyId = "string",
                    },
                },
                SecondaryVnics = new[]
                {
                    new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionSecondaryVnicArgs
                    {
                        CreateVnicDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsArgs
                        {
                            AssignIpv6ip = false,
                            AssignPrivateDnsRecord = false,
                            AssignPublicIp = false,
                            DefinedTags = 
                            {
                                { "string", "any" },
                            },
                            DisplayName = "string",
                            FreeformTags = 
                            {
                                { "string", "any" },
                            },
                            HostnameLabel = "string",
                            Ipv6addressIpv6subnetCidrPairDetails = new[]
                            {
                                new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs
                                {
                                    Ipv6address = "string",
                                    Ipv6subnetCidr = "string",
                                },
                            },
                            NsgIds = new[]
                            {
                                "string",
                            },
                            PrivateIp = "string",
                            SkipSourceDestCheck = false,
                            SubnetId = "string",
                        },
                        DisplayName = "string",
                        NicIndex = 0,
                    },
                },
            },
        },
        SecondaryVnics = new[]
        {
            new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsSecondaryVnicArgs
            {
                CreateVnicDetails = new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsArgs
                {
                    AssignIpv6ip = false,
                    AssignPrivateDnsRecord = false,
                    AssignPublicIp = false,
                    DefinedTags = 
                    {
                        { "string", "any" },
                    },
                    DisplayName = "string",
                    FreeformTags = 
                    {
                        { "string", "any" },
                    },
                    HostnameLabel = "string",
                    Ipv6addressIpv6subnetCidrPairDetails = new[]
                    {
                        new Oci.Core.Inputs.InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs
                        {
                            Ipv6address = "string",
                            Ipv6subnetCidr = "string",
                        },
                    },
                    NsgIds = new[]
                    {
                        "string",
                    },
                    PrivateIp = "string",
                    SkipSourceDestCheck = false,
                    SubnetId = "string",
                },
                DisplayName = "string",
                NicIndex = 0,
            },
        },
    },
    InstanceId = "string",
    Source = "string",
});
example, err := Core.NewInstanceConfiguration(ctx, "instanceConfigurationResource", &Core.InstanceConfigurationArgs{
	CompartmentId: pulumi.String("string"),
	DefinedTags: pulumi.Map{
		"string": pulumi.Any("any"),
	},
	DisplayName: pulumi.String("string"),
	FreeformTags: pulumi.Map{
		"string": pulumi.Any("any"),
	},
	InstanceDetails: &core.InstanceConfigurationInstanceDetailsArgs{
		InstanceType: pulumi.String("string"),
		BlockVolumes: core.InstanceConfigurationInstanceDetailsBlockVolumeArray{
			&core.InstanceConfigurationInstanceDetailsBlockVolumeArgs{
				AttachDetails: &core.InstanceConfigurationInstanceDetailsBlockVolumeAttachDetailsArgs{
					Type:                           pulumi.String("string"),
					Device:                         pulumi.String("string"),
					DisplayName:                    pulumi.String("string"),
					IsPvEncryptionInTransitEnabled: pulumi.Bool(false),
					IsReadOnly:                     pulumi.Bool(false),
					IsShareable:                    pulumi.Bool(false),
					UseChap:                        pulumi.Bool(false),
				},
				CreateDetails: &core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsArgs{
					AutotunePolicies: core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsAutotunePolicyArray{
						&core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsAutotunePolicyArgs{
							AutotuneType: pulumi.String("string"),
							MaxVpusPerGb: pulumi.String("string"),
						},
					},
					AvailabilityDomain: pulumi.String("string"),
					BackupPolicyId:     pulumi.String("string"),
					BlockVolumeReplicas: &core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsBlockVolumeReplicasArgs{
						AvailabilityDomain: pulumi.String("string"),
						DisplayName:        pulumi.String("string"),
					},
					ClusterPlacementGroupId: pulumi.String("string"),
					CompartmentId:           pulumi.String("string"),
					DefinedTags: pulumi.Map{
						"string": pulumi.Any("any"),
					},
					DisplayName: pulumi.String("string"),
					FreeformTags: pulumi.Map{
						"string": pulumi.Any("any"),
					},
					IsAutoTuneEnabled: pulumi.Bool(false),
					KmsKeyId:          pulumi.String("string"),
					SizeInGbs:         pulumi.String("string"),
					SourceDetails: &core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsSourceDetailsArgs{
						Type: pulumi.String("string"),
						Id:   pulumi.String("string"),
					},
					VpusPerGb: pulumi.String("string"),
				},
				VolumeId: pulumi.String("string"),
			},
		},
		LaunchDetails: &core.InstanceConfigurationInstanceDetailsLaunchDetailsArgs{
			AgentConfig: &core.InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigArgs{
				AreAllPluginsDisabled: pulumi.Bool(false),
				IsManagementDisabled:  pulumi.Bool(false),
				IsMonitoringDisabled:  pulumi.Bool(false),
				PluginsConfigs: core.InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigArray{
					&core.InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigArgs{
						DesiredState: pulumi.String("string"),
						Name:         pulumi.String("string"),
					},
				},
			},
			AvailabilityConfig: &core.InstanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigArgs{
				IsLiveMigrationPreferred: pulumi.Bool(false),
				RecoveryAction:           pulumi.String("string"),
			},
			AvailabilityDomain:      pulumi.String("string"),
			CapacityReservationId:   pulumi.String("string"),
			ClusterPlacementGroupId: pulumi.String("string"),
			CompartmentId:           pulumi.String("string"),
			CreateVnicDetails: &core.InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsArgs{
				AssignIpv6ip:           pulumi.Bool(false),
				AssignPrivateDnsRecord: pulumi.Bool(false),
				AssignPublicIp:         pulumi.Bool(false),
				DefinedTags: pulumi.Map{
					"string": pulumi.Any("any"),
				},
				DisplayName: pulumi.String("string"),
				FreeformTags: pulumi.Map{
					"string": pulumi.Any("any"),
				},
				HostnameLabel: pulumi.String("string"),
				Ipv6addressIpv6subnetCidrPairDetails: core.InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArray{
					&core.InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs{
						Ipv6address:    pulumi.String("string"),
						Ipv6subnetCidr: pulumi.String("string"),
					},
				},
				NsgIds: pulumi.StringArray{
					pulumi.String("string"),
				},
				PrivateIp:           pulumi.String("string"),
				SkipSourceDestCheck: pulumi.Bool(false),
				SubnetId:            pulumi.String("string"),
			},
			DedicatedVmHostId: pulumi.String("string"),
			DefinedTags: pulumi.Map{
				"string": pulumi.Any("any"),
			},
			DisplayName: pulumi.String("string"),
			ExtendedMetadata: pulumi.Map{
				"string": pulumi.Any("any"),
			},
			FaultDomain: pulumi.String("string"),
			FreeformTags: pulumi.Map{
				"string": pulumi.Any("any"),
			},
			InstanceOptions: &core.InstanceConfigurationInstanceDetailsLaunchDetailsInstanceOptionsArgs{
				AreLegacyImdsEndpointsDisabled: pulumi.Bool(false),
			},
			IpxeScript:                     pulumi.String("string"),
			IsPvEncryptionInTransitEnabled: pulumi.Bool(false),
			LaunchMode:                     pulumi.String("string"),
			LaunchOptions: &core.InstanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsArgs{
				BootVolumeType:                  pulumi.String("string"),
				Firmware:                        pulumi.String("string"),
				IsConsistentVolumeNamingEnabled: pulumi.Bool(false),
				IsPvEncryptionInTransitEnabled:  pulumi.Bool(false),
				NetworkType:                     pulumi.String("string"),
				RemoteDataVolumeType:            pulumi.String("string"),
			},
			Metadata: pulumi.Map{
				"string": pulumi.Any("any"),
			},
			PlatformConfig: &core.InstanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigArgs{
				Type:                          pulumi.String("string"),
				AreVirtualInstructionsEnabled: pulumi.Bool(false),
				ConfigMap: pulumi.Map{
					"string": pulumi.Any("any"),
				},
				IsAccessControlServiceEnabled:            pulumi.Bool(false),
				IsInputOutputMemoryManagementUnitEnabled: pulumi.Bool(false),
				IsMeasuredBootEnabled:                    pulumi.Bool(false),
				IsMemoryEncryptionEnabled:                pulumi.Bool(false),
				IsSecureBootEnabled:                      pulumi.Bool(false),
				IsSymmetricMultiThreadingEnabled:         pulumi.Bool(false),
				IsTrustedPlatformModuleEnabled:           pulumi.Bool(false),
				NumaNodesPerSocket:                       pulumi.String("string"),
				PercentageOfCoresEnabled:                 pulumi.Int(0),
			},
			PreemptibleInstanceConfig: &core.InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigArgs{
				PreemptionAction: &core.InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs{
					Type:               pulumi.String("string"),
					PreserveBootVolume: pulumi.Bool(false),
				},
			},
			PreferredMaintenanceAction: pulumi.String("string"),
			Shape:                      pulumi.String("string"),
			ShapeConfig: &core.InstanceConfigurationInstanceDetailsLaunchDetailsShapeConfigArgs{
				BaselineOcpuUtilization: pulumi.String("string"),
				MemoryInGbs:             pulumi.Float64(0),
				Nvmes:                   pulumi.Int(0),
				Ocpus:                   pulumi.Float64(0),
				Vcpus:                   pulumi.Int(0),
			},
			SourceDetails: &core.InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsArgs{
				SourceType:          pulumi.String("string"),
				BootVolumeId:        pulumi.String("string"),
				BootVolumeSizeInGbs: pulumi.String("string"),
				BootVolumeVpusPerGb: pulumi.String("string"),
				ImageId:             pulumi.String("string"),
				InstanceSourceImageFilterDetails: &core.InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs{
					CompartmentId: pulumi.String("string"),
					DefinedTagsFilter: pulumi.Map{
						"string": pulumi.Any("any"),
					},
					OperatingSystem:        pulumi.String("string"),
					OperatingSystemVersion: pulumi.String("string"),
				},
				KmsKeyId: pulumi.String("string"),
			},
		},
		Options: core.InstanceConfigurationInstanceDetailsOptionArray{
			&core.InstanceConfigurationInstanceDetailsOptionArgs{
				BlockVolumes: core.InstanceConfigurationInstanceDetailsOptionBlockVolumeArray{
					&core.InstanceConfigurationInstanceDetailsOptionBlockVolumeArgs{
						AttachDetails: &core.InstanceConfigurationInstanceDetailsOptionBlockVolumeAttachDetailsArgs{
							Type:                           pulumi.String("string"),
							Device:                         pulumi.String("string"),
							DisplayName:                    pulumi.String("string"),
							IsPvEncryptionInTransitEnabled: pulumi.Bool(false),
							IsReadOnly:                     pulumi.Bool(false),
							IsShareable:                    pulumi.Bool(false),
							UseChap:                        pulumi.Bool(false),
						},
						CreateDetails: &core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsArgs{
							AutotunePolicies: core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsAutotunePolicyArray{
								&core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsAutotunePolicyArgs{
									AutotuneType: pulumi.String("string"),
									MaxVpusPerGb: pulumi.String("string"),
								},
							},
							AvailabilityDomain: pulumi.String("string"),
							BackupPolicyId:     pulumi.String("string"),
							BlockVolumeReplicas: &core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsBlockVolumeReplicasArgs{
								AvailabilityDomain: pulumi.String("string"),
								DisplayName:        pulumi.String("string"),
							},
							ClusterPlacementGroupId: pulumi.String("string"),
							CompartmentId:           pulumi.String("string"),
							DefinedTags: pulumi.Map{
								"string": pulumi.Any("any"),
							},
							DisplayName: pulumi.String("string"),
							FreeformTags: pulumi.Map{
								"string": pulumi.Any("any"),
							},
							IsAutoTuneEnabled: pulumi.Bool(false),
							KmsKeyId:          pulumi.String("string"),
							SizeInGbs:         pulumi.String("string"),
							SourceDetails: &core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsSourceDetailsArgs{
								Type: pulumi.String("string"),
								Id:   pulumi.String("string"),
							},
							VpusPerGb: pulumi.String("string"),
						},
						VolumeId: pulumi.String("string"),
					},
				},
				LaunchDetails: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsArgs{
					AgentConfig: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigArgs{
						AreAllPluginsDisabled: pulumi.Bool(false),
						IsManagementDisabled:  pulumi.Bool(false),
						IsMonitoringDisabled:  pulumi.Bool(false),
						PluginsConfigs: core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigPluginsConfigArray{
							&core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigPluginsConfigArgs{
								DesiredState: pulumi.String("string"),
								Name:         pulumi.String("string"),
							},
						},
					},
					AvailabilityConfig: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAvailabilityConfigArgs{
						IsLiveMigrationPreferred: pulumi.Bool(false),
						RecoveryAction:           pulumi.String("string"),
					},
					AvailabilityDomain:      pulumi.String("string"),
					CapacityReservationId:   pulumi.String("string"),
					ClusterPlacementGroupId: pulumi.String("string"),
					CompartmentId:           pulumi.String("string"),
					CreateVnicDetails: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsArgs{
						AssignIpv6ip:           pulumi.Bool(false),
						AssignPrivateDnsRecord: pulumi.Bool(false),
						AssignPublicIp:         pulumi.Bool(false),
						DefinedTags: pulumi.Map{
							"string": pulumi.Any("any"),
						},
						DisplayName: pulumi.String("string"),
						FreeformTags: pulumi.Map{
							"string": pulumi.Any("any"),
						},
						HostnameLabel: pulumi.String("string"),
						Ipv6addressIpv6subnetCidrPairDetails: core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArray{
							&core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs{
								Ipv6address:    pulumi.String("string"),
								Ipv6subnetCidr: pulumi.String("string"),
							},
						},
						NsgIds: pulumi.StringArray{
							pulumi.String("string"),
						},
						PrivateIp:           pulumi.String("string"),
						SkipSourceDestCheck: pulumi.Bool(false),
						SubnetId:            pulumi.String("string"),
					},
					DedicatedVmHostId: pulumi.String("string"),
					DefinedTags: pulumi.Map{
						"string": pulumi.Any("any"),
					},
					DisplayName: pulumi.String("string"),
					ExtendedMetadata: pulumi.Map{
						"string": pulumi.Any("any"),
					},
					FaultDomain: pulumi.String("string"),
					FreeformTags: pulumi.Map{
						"string": pulumi.Any("any"),
					},
					InstanceOptions: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsInstanceOptionsArgs{
						AreLegacyImdsEndpointsDisabled: pulumi.Bool(false),
					},
					IpxeScript:                     pulumi.String("string"),
					IsPvEncryptionInTransitEnabled: pulumi.Bool(false),
					LaunchMode:                     pulumi.String("string"),
					LaunchOptions: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsLaunchOptionsArgs{
						BootVolumeType:                  pulumi.String("string"),
						Firmware:                        pulumi.String("string"),
						IsConsistentVolumeNamingEnabled: pulumi.Bool(false),
						IsPvEncryptionInTransitEnabled:  pulumi.Bool(false),
						NetworkType:                     pulumi.String("string"),
						RemoteDataVolumeType:            pulumi.String("string"),
					},
					Metadata: pulumi.Map{
						"string": pulumi.Any("any"),
					},
					PlatformConfig: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPlatformConfigArgs{
						Type:                                     pulumi.String("string"),
						AreVirtualInstructionsEnabled:            pulumi.Bool(false),
						IsAccessControlServiceEnabled:            pulumi.Bool(false),
						IsInputOutputMemoryManagementUnitEnabled: pulumi.Bool(false),
						IsMeasuredBootEnabled:                    pulumi.Bool(false),
						IsMemoryEncryptionEnabled:                pulumi.Bool(false),
						IsSecureBootEnabled:                      pulumi.Bool(false),
						IsSymmetricMultiThreadingEnabled:         pulumi.Bool(false),
						IsTrustedPlatformModuleEnabled:           pulumi.Bool(false),
						NumaNodesPerSocket:                       pulumi.String("string"),
						PercentageOfCoresEnabled:                 pulumi.Int(0),
					},
					PreemptibleInstanceConfig: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigArgs{
						PreemptionAction: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs{
							Type:               pulumi.String("string"),
							PreserveBootVolume: pulumi.Bool(false),
						},
					},
					PreferredMaintenanceAction: pulumi.String("string"),
					Shape:                      pulumi.String("string"),
					ShapeConfig: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsShapeConfigArgs{
						BaselineOcpuUtilization: pulumi.String("string"),
						MemoryInGbs:             pulumi.Float64(0),
						Nvmes:                   pulumi.Int(0),
						Ocpus:                   pulumi.Float64(0),
						Vcpus:                   pulumi.Int(0),
					},
					SourceDetails: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsArgs{
						SourceType:          pulumi.String("string"),
						BootVolumeId:        pulumi.String("string"),
						BootVolumeSizeInGbs: pulumi.String("string"),
						BootVolumeVpusPerGb: pulumi.String("string"),
						ImageId:             pulumi.String("string"),
						InstanceSourceImageFilterDetails: &core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs{
							CompartmentId: pulumi.String("string"),
							DefinedTagsFilter: pulumi.Map{
								"string": pulumi.Any("any"),
							},
							OperatingSystem:        pulumi.String("string"),
							OperatingSystemVersion: pulumi.String("string"),
						},
						KmsKeyId: pulumi.String("string"),
					},
				},
				SecondaryVnics: core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicArray{
					&core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicArgs{
						CreateVnicDetails: &core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsArgs{
							AssignIpv6ip:           pulumi.Bool(false),
							AssignPrivateDnsRecord: pulumi.Bool(false),
							AssignPublicIp:         pulumi.Bool(false),
							DefinedTags: pulumi.Map{
								"string": pulumi.Any("any"),
							},
							DisplayName: pulumi.String("string"),
							FreeformTags: pulumi.Map{
								"string": pulumi.Any("any"),
							},
							HostnameLabel: pulumi.String("string"),
							Ipv6addressIpv6subnetCidrPairDetails: core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArray{
								&core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs{
									Ipv6address:    pulumi.String("string"),
									Ipv6subnetCidr: pulumi.String("string"),
								},
							},
							NsgIds: pulumi.StringArray{
								pulumi.String("string"),
							},
							PrivateIp:           pulumi.String("string"),
							SkipSourceDestCheck: pulumi.Bool(false),
							SubnetId:            pulumi.String("string"),
						},
						DisplayName: pulumi.String("string"),
						NicIndex:    pulumi.Int(0),
					},
				},
			},
		},
		SecondaryVnics: core.InstanceConfigurationInstanceDetailsSecondaryVnicArray{
			&core.InstanceConfigurationInstanceDetailsSecondaryVnicArgs{
				CreateVnicDetails: &core.InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsArgs{
					AssignIpv6ip:           pulumi.Bool(false),
					AssignPrivateDnsRecord: pulumi.Bool(false),
					AssignPublicIp:         pulumi.Bool(false),
					DefinedTags: pulumi.Map{
						"string": pulumi.Any("any"),
					},
					DisplayName: pulumi.String("string"),
					FreeformTags: pulumi.Map{
						"string": pulumi.Any("any"),
					},
					HostnameLabel: pulumi.String("string"),
					Ipv6addressIpv6subnetCidrPairDetails: core.InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArray{
						&core.InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs{
							Ipv6address:    pulumi.String("string"),
							Ipv6subnetCidr: pulumi.String("string"),
						},
					},
					NsgIds: pulumi.StringArray{
						pulumi.String("string"),
					},
					PrivateIp:           pulumi.String("string"),
					SkipSourceDestCheck: pulumi.Bool(false),
					SubnetId:            pulumi.String("string"),
				},
				DisplayName: pulumi.String("string"),
				NicIndex:    pulumi.Int(0),
			},
		},
	},
	InstanceId: pulumi.String("string"),
	Source:     pulumi.String("string"),
})
var instanceConfigurationResource = new InstanceConfiguration("instanceConfigurationResource", InstanceConfigurationArgs.builder()
    .compartmentId("string")
    .definedTags(Map.of("string", "any"))
    .displayName("string")
    .freeformTags(Map.of("string", "any"))
    .instanceDetails(InstanceConfigurationInstanceDetailsArgs.builder()
        .instanceType("string")
        .blockVolumes(InstanceConfigurationInstanceDetailsBlockVolumeArgs.builder()
            .attachDetails(InstanceConfigurationInstanceDetailsBlockVolumeAttachDetailsArgs.builder()
                .type("string")
                .device("string")
                .displayName("string")
                .isPvEncryptionInTransitEnabled(false)
                .isReadOnly(false)
                .isShareable(false)
                .useChap(false)
                .build())
            .createDetails(InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsArgs.builder()
                .autotunePolicies(InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsAutotunePolicyArgs.builder()
                    .autotuneType("string")
                    .maxVpusPerGb("string")
                    .build())
                .availabilityDomain("string")
                .backupPolicyId("string")
                .blockVolumeReplicas(InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsBlockVolumeReplicasArgs.builder()
                    .availabilityDomain("string")
                    .displayName("string")
                    .build())
                .clusterPlacementGroupId("string")
                .compartmentId("string")
                .definedTags(Map.of("string", "any"))
                .displayName("string")
                .freeformTags(Map.of("string", "any"))
                .isAutoTuneEnabled(false)
                .kmsKeyId("string")
                .sizeInGbs("string")
                .sourceDetails(InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsSourceDetailsArgs.builder()
                    .type("string")
                    .id("string")
                    .build())
                .vpusPerGb("string")
                .build())
            .volumeId("string")
            .build())
        .launchDetails(InstanceConfigurationInstanceDetailsLaunchDetailsArgs.builder()
            .agentConfig(InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigArgs.builder()
                .areAllPluginsDisabled(false)
                .isManagementDisabled(false)
                .isMonitoringDisabled(false)
                .pluginsConfigs(InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigArgs.builder()
                    .desiredState("string")
                    .name("string")
                    .build())
                .build())
            .availabilityConfig(InstanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigArgs.builder()
                .isLiveMigrationPreferred(false)
                .recoveryAction("string")
                .build())
            .availabilityDomain("string")
            .capacityReservationId("string")
            .clusterPlacementGroupId("string")
            .compartmentId("string")
            .createVnicDetails(InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsArgs.builder()
                .assignIpv6ip(false)
                .assignPrivateDnsRecord(false)
                .assignPublicIp(false)
                .definedTags(Map.of("string", "any"))
                .displayName("string")
                .freeformTags(Map.of("string", "any"))
                .hostnameLabel("string")
                .ipv6addressIpv6subnetCidrPairDetails(InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs.builder()
                    .ipv6address("string")
                    .ipv6subnetCidr("string")
                    .build())
                .nsgIds("string")
                .privateIp("string")
                .skipSourceDestCheck(false)
                .subnetId("string")
                .build())
            .dedicatedVmHostId("string")
            .definedTags(Map.of("string", "any"))
            .displayName("string")
            .extendedMetadata(Map.of("string", "any"))
            .faultDomain("string")
            .freeformTags(Map.of("string", "any"))
            .instanceOptions(InstanceConfigurationInstanceDetailsLaunchDetailsInstanceOptionsArgs.builder()
                .areLegacyImdsEndpointsDisabled(false)
                .build())
            .ipxeScript("string")
            .isPvEncryptionInTransitEnabled(false)
            .launchMode("string")
            .launchOptions(InstanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsArgs.builder()
                .bootVolumeType("string")
                .firmware("string")
                .isConsistentVolumeNamingEnabled(false)
                .isPvEncryptionInTransitEnabled(false)
                .networkType("string")
                .remoteDataVolumeType("string")
                .build())
            .metadata(Map.of("string", "any"))
            .platformConfig(InstanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigArgs.builder()
                .type("string")
                .areVirtualInstructionsEnabled(false)
                .configMap(Map.of("string", "any"))
                .isAccessControlServiceEnabled(false)
                .isInputOutputMemoryManagementUnitEnabled(false)
                .isMeasuredBootEnabled(false)
                .isMemoryEncryptionEnabled(false)
                .isSecureBootEnabled(false)
                .isSymmetricMultiThreadingEnabled(false)
                .isTrustedPlatformModuleEnabled(false)
                .numaNodesPerSocket("string")
                .percentageOfCoresEnabled(0)
                .build())
            .preemptibleInstanceConfig(InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigArgs.builder()
                .preemptionAction(InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs.builder()
                    .type("string")
                    .preserveBootVolume(false)
                    .build())
                .build())
            .preferredMaintenanceAction("string")
            .shape("string")
            .shapeConfig(InstanceConfigurationInstanceDetailsLaunchDetailsShapeConfigArgs.builder()
                .baselineOcpuUtilization("string")
                .memoryInGbs(0)
                .nvmes(0)
                .ocpus(0)
                .vcpus(0)
                .build())
            .sourceDetails(InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsArgs.builder()
                .sourceType("string")
                .bootVolumeId("string")
                .bootVolumeSizeInGbs("string")
                .bootVolumeVpusPerGb("string")
                .imageId("string")
                .instanceSourceImageFilterDetails(InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs.builder()
                    .compartmentId("string")
                    .definedTagsFilter(Map.of("string", "any"))
                    .operatingSystem("string")
                    .operatingSystemVersion("string")
                    .build())
                .kmsKeyId("string")
                .build())
            .build())
        .options(InstanceConfigurationInstanceDetailsOptionArgs.builder()
            .blockVolumes(InstanceConfigurationInstanceDetailsOptionBlockVolumeArgs.builder()
                .attachDetails(InstanceConfigurationInstanceDetailsOptionBlockVolumeAttachDetailsArgs.builder()
                    .type("string")
                    .device("string")
                    .displayName("string")
                    .isPvEncryptionInTransitEnabled(false)
                    .isReadOnly(false)
                    .isShareable(false)
                    .useChap(false)
                    .build())
                .createDetails(InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsArgs.builder()
                    .autotunePolicies(InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsAutotunePolicyArgs.builder()
                        .autotuneType("string")
                        .maxVpusPerGb("string")
                        .build())
                    .availabilityDomain("string")
                    .backupPolicyId("string")
                    .blockVolumeReplicas(InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsBlockVolumeReplicasArgs.builder()
                        .availabilityDomain("string")
                        .displayName("string")
                        .build())
                    .clusterPlacementGroupId("string")
                    .compartmentId("string")
                    .definedTags(Map.of("string", "any"))
                    .displayName("string")
                    .freeformTags(Map.of("string", "any"))
                    .isAutoTuneEnabled(false)
                    .kmsKeyId("string")
                    .sizeInGbs("string")
                    .sourceDetails(InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsSourceDetailsArgs.builder()
                        .type("string")
                        .id("string")
                        .build())
                    .vpusPerGb("string")
                    .build())
                .volumeId("string")
                .build())
            .launchDetails(InstanceConfigurationInstanceDetailsOptionLaunchDetailsArgs.builder()
                .agentConfig(InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigArgs.builder()
                    .areAllPluginsDisabled(false)
                    .isManagementDisabled(false)
                    .isMonitoringDisabled(false)
                    .pluginsConfigs(InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigPluginsConfigArgs.builder()
                        .desiredState("string")
                        .name("string")
                        .build())
                    .build())
                .availabilityConfig(InstanceConfigurationInstanceDetailsOptionLaunchDetailsAvailabilityConfigArgs.builder()
                    .isLiveMigrationPreferred(false)
                    .recoveryAction("string")
                    .build())
                .availabilityDomain("string")
                .capacityReservationId("string")
                .clusterPlacementGroupId("string")
                .compartmentId("string")
                .createVnicDetails(InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsArgs.builder()
                    .assignIpv6ip(false)
                    .assignPrivateDnsRecord(false)
                    .assignPublicIp(false)
                    .definedTags(Map.of("string", "any"))
                    .displayName("string")
                    .freeformTags(Map.of("string", "any"))
                    .hostnameLabel("string")
                    .ipv6addressIpv6subnetCidrPairDetails(InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs.builder()
                        .ipv6address("string")
                        .ipv6subnetCidr("string")
                        .build())
                    .nsgIds("string")
                    .privateIp("string")
                    .skipSourceDestCheck(false)
                    .subnetId("string")
                    .build())
                .dedicatedVmHostId("string")
                .definedTags(Map.of("string", "any"))
                .displayName("string")
                .extendedMetadata(Map.of("string", "any"))
                .faultDomain("string")
                .freeformTags(Map.of("string", "any"))
                .instanceOptions(InstanceConfigurationInstanceDetailsOptionLaunchDetailsInstanceOptionsArgs.builder()
                    .areLegacyImdsEndpointsDisabled(false)
                    .build())
                .ipxeScript("string")
                .isPvEncryptionInTransitEnabled(false)
                .launchMode("string")
                .launchOptions(InstanceConfigurationInstanceDetailsOptionLaunchDetailsLaunchOptionsArgs.builder()
                    .bootVolumeType("string")
                    .firmware("string")
                    .isConsistentVolumeNamingEnabled(false)
                    .isPvEncryptionInTransitEnabled(false)
                    .networkType("string")
                    .remoteDataVolumeType("string")
                    .build())
                .metadata(Map.of("string", "any"))
                .platformConfig(InstanceConfigurationInstanceDetailsOptionLaunchDetailsPlatformConfigArgs.builder()
                    .type("string")
                    .areVirtualInstructionsEnabled(false)
                    .isAccessControlServiceEnabled(false)
                    .isInputOutputMemoryManagementUnitEnabled(false)
                    .isMeasuredBootEnabled(false)
                    .isMemoryEncryptionEnabled(false)
                    .isSecureBootEnabled(false)
                    .isSymmetricMultiThreadingEnabled(false)
                    .isTrustedPlatformModuleEnabled(false)
                    .numaNodesPerSocket("string")
                    .percentageOfCoresEnabled(0)
                    .build())
                .preemptibleInstanceConfig(InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigArgs.builder()
                    .preemptionAction(InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs.builder()
                        .type("string")
                        .preserveBootVolume(false)
                        .build())
                    .build())
                .preferredMaintenanceAction("string")
                .shape("string")
                .shapeConfig(InstanceConfigurationInstanceDetailsOptionLaunchDetailsShapeConfigArgs.builder()
                    .baselineOcpuUtilization("string")
                    .memoryInGbs(0)
                    .nvmes(0)
                    .ocpus(0)
                    .vcpus(0)
                    .build())
                .sourceDetails(InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsArgs.builder()
                    .sourceType("string")
                    .bootVolumeId("string")
                    .bootVolumeSizeInGbs("string")
                    .bootVolumeVpusPerGb("string")
                    .imageId("string")
                    .instanceSourceImageFilterDetails(InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs.builder()
                        .compartmentId("string")
                        .definedTagsFilter(Map.of("string", "any"))
                        .operatingSystem("string")
                        .operatingSystemVersion("string")
                        .build())
                    .kmsKeyId("string")
                    .build())
                .build())
            .secondaryVnics(InstanceConfigurationInstanceDetailsOptionSecondaryVnicArgs.builder()
                .createVnicDetails(InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsArgs.builder()
                    .assignIpv6ip(false)
                    .assignPrivateDnsRecord(false)
                    .assignPublicIp(false)
                    .definedTags(Map.of("string", "any"))
                    .displayName("string")
                    .freeformTags(Map.of("string", "any"))
                    .hostnameLabel("string")
                    .ipv6addressIpv6subnetCidrPairDetails(InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs.builder()
                        .ipv6address("string")
                        .ipv6subnetCidr("string")
                        .build())
                    .nsgIds("string")
                    .privateIp("string")
                    .skipSourceDestCheck(false)
                    .subnetId("string")
                    .build())
                .displayName("string")
                .nicIndex(0)
                .build())
            .build())
        .secondaryVnics(InstanceConfigurationInstanceDetailsSecondaryVnicArgs.builder()
            .createVnicDetails(InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsArgs.builder()
                .assignIpv6ip(false)
                .assignPrivateDnsRecord(false)
                .assignPublicIp(false)
                .definedTags(Map.of("string", "any"))
                .displayName("string")
                .freeformTags(Map.of("string", "any"))
                .hostnameLabel("string")
                .ipv6addressIpv6subnetCidrPairDetails(InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs.builder()
                    .ipv6address("string")
                    .ipv6subnetCidr("string")
                    .build())
                .nsgIds("string")
                .privateIp("string")
                .skipSourceDestCheck(false)
                .subnetId("string")
                .build())
            .displayName("string")
            .nicIndex(0)
            .build())
        .build())
    .instanceId("string")
    .source("string")
    .build());
instance_configuration_resource = oci.core.InstanceConfiguration("instanceConfigurationResource",
    compartment_id="string",
    defined_tags={
        "string": "any",
    },
    display_name="string",
    freeform_tags={
        "string": "any",
    },
    instance_details=oci.core.InstanceConfigurationInstanceDetailsArgs(
        instance_type="string",
        block_volumes=[oci.core.InstanceConfigurationInstanceDetailsBlockVolumeArgs(
            attach_details=oci.core.InstanceConfigurationInstanceDetailsBlockVolumeAttachDetailsArgs(
                type="string",
                device="string",
                display_name="string",
                is_pv_encryption_in_transit_enabled=False,
                is_read_only=False,
                is_shareable=False,
                use_chap=False,
            ),
            create_details=oci.core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsArgs(
                autotune_policies=[oci.core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsAutotunePolicyArgs(
                    autotune_type="string",
                    max_vpus_per_gb="string",
                )],
                availability_domain="string",
                backup_policy_id="string",
                block_volume_replicas=oci.core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsBlockVolumeReplicasArgs(
                    availability_domain="string",
                    display_name="string",
                ),
                cluster_placement_group_id="string",
                compartment_id="string",
                defined_tags={
                    "string": "any",
                },
                display_name="string",
                freeform_tags={
                    "string": "any",
                },
                is_auto_tune_enabled=False,
                kms_key_id="string",
                size_in_gbs="string",
                source_details=oci.core.InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsSourceDetailsArgs(
                    type="string",
                    id="string",
                ),
                vpus_per_gb="string",
            ),
            volume_id="string",
        )],
        launch_details=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsArgs(
            agent_config=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigArgs(
                are_all_plugins_disabled=False,
                is_management_disabled=False,
                is_monitoring_disabled=False,
                plugins_configs=[oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigArgs(
                    desired_state="string",
                    name="string",
                )],
            ),
            availability_config=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigArgs(
                is_live_migration_preferred=False,
                recovery_action="string",
            ),
            availability_domain="string",
            capacity_reservation_id="string",
            cluster_placement_group_id="string",
            compartment_id="string",
            create_vnic_details=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsArgs(
                assign_ipv6ip=False,
                assign_private_dns_record=False,
                assign_public_ip=False,
                defined_tags={
                    "string": "any",
                },
                display_name="string",
                freeform_tags={
                    "string": "any",
                },
                hostname_label="string",
                ipv6address_ipv6subnet_cidr_pair_details=[oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs(
                    ipv6address="string",
                    ipv6subnet_cidr="string",
                )],
                nsg_ids=["string"],
                private_ip="string",
                skip_source_dest_check=False,
                subnet_id="string",
            ),
            dedicated_vm_host_id="string",
            defined_tags={
                "string": "any",
            },
            display_name="string",
            extended_metadata={
                "string": "any",
            },
            fault_domain="string",
            freeform_tags={
                "string": "any",
            },
            instance_options=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsInstanceOptionsArgs(
                are_legacy_imds_endpoints_disabled=False,
            ),
            ipxe_script="string",
            is_pv_encryption_in_transit_enabled=False,
            launch_mode="string",
            launch_options=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsArgs(
                boot_volume_type="string",
                firmware="string",
                is_consistent_volume_naming_enabled=False,
                is_pv_encryption_in_transit_enabled=False,
                network_type="string",
                remote_data_volume_type="string",
            ),
            metadata={
                "string": "any",
            },
            platform_config=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigArgs(
                type="string",
                are_virtual_instructions_enabled=False,
                config_map={
                    "string": "any",
                },
                is_access_control_service_enabled=False,
                is_input_output_memory_management_unit_enabled=False,
                is_measured_boot_enabled=False,
                is_memory_encryption_enabled=False,
                is_secure_boot_enabled=False,
                is_symmetric_multi_threading_enabled=False,
                is_trusted_platform_module_enabled=False,
                numa_nodes_per_socket="string",
                percentage_of_cores_enabled=0,
            ),
            preemptible_instance_config=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigArgs(
                preemption_action=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs(
                    type="string",
                    preserve_boot_volume=False,
                ),
            ),
            preferred_maintenance_action="string",
            shape="string",
            shape_config=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsShapeConfigArgs(
                baseline_ocpu_utilization="string",
                memory_in_gbs=0,
                nvmes=0,
                ocpus=0,
                vcpus=0,
            ),
            source_details=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsArgs(
                source_type="string",
                boot_volume_id="string",
                boot_volume_size_in_gbs="string",
                boot_volume_vpus_per_gb="string",
                image_id="string",
                instance_source_image_filter_details=oci.core.InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs(
                    compartment_id="string",
                    defined_tags_filter={
                        "string": "any",
                    },
                    operating_system="string",
                    operating_system_version="string",
                ),
                kms_key_id="string",
            ),
        ),
        options=[oci.core.InstanceConfigurationInstanceDetailsOptionArgs(
            block_volumes=[oci.core.InstanceConfigurationInstanceDetailsOptionBlockVolumeArgs(
                attach_details=oci.core.InstanceConfigurationInstanceDetailsOptionBlockVolumeAttachDetailsArgs(
                    type="string",
                    device="string",
                    display_name="string",
                    is_pv_encryption_in_transit_enabled=False,
                    is_read_only=False,
                    is_shareable=False,
                    use_chap=False,
                ),
                create_details=oci.core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsArgs(
                    autotune_policies=[oci.core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsAutotunePolicyArgs(
                        autotune_type="string",
                        max_vpus_per_gb="string",
                    )],
                    availability_domain="string",
                    backup_policy_id="string",
                    block_volume_replicas=oci.core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsBlockVolumeReplicasArgs(
                        availability_domain="string",
                        display_name="string",
                    ),
                    cluster_placement_group_id="string",
                    compartment_id="string",
                    defined_tags={
                        "string": "any",
                    },
                    display_name="string",
                    freeform_tags={
                        "string": "any",
                    },
                    is_auto_tune_enabled=False,
                    kms_key_id="string",
                    size_in_gbs="string",
                    source_details=oci.core.InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsSourceDetailsArgs(
                        type="string",
                        id="string",
                    ),
                    vpus_per_gb="string",
                ),
                volume_id="string",
            )],
            launch_details=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsArgs(
                agent_config=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigArgs(
                    are_all_plugins_disabled=False,
                    is_management_disabled=False,
                    is_monitoring_disabled=False,
                    plugins_configs=[oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigPluginsConfigArgs(
                        desired_state="string",
                        name="string",
                    )],
                ),
                availability_config=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsAvailabilityConfigArgs(
                    is_live_migration_preferred=False,
                    recovery_action="string",
                ),
                availability_domain="string",
                capacity_reservation_id="string",
                cluster_placement_group_id="string",
                compartment_id="string",
                create_vnic_details=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsArgs(
                    assign_ipv6ip=False,
                    assign_private_dns_record=False,
                    assign_public_ip=False,
                    defined_tags={
                        "string": "any",
                    },
                    display_name="string",
                    freeform_tags={
                        "string": "any",
                    },
                    hostname_label="string",
                    ipv6address_ipv6subnet_cidr_pair_details=[oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs(
                        ipv6address="string",
                        ipv6subnet_cidr="string",
                    )],
                    nsg_ids=["string"],
                    private_ip="string",
                    skip_source_dest_check=False,
                    subnet_id="string",
                ),
                dedicated_vm_host_id="string",
                defined_tags={
                    "string": "any",
                },
                display_name="string",
                extended_metadata={
                    "string": "any",
                },
                fault_domain="string",
                freeform_tags={
                    "string": "any",
                },
                instance_options=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsInstanceOptionsArgs(
                    are_legacy_imds_endpoints_disabled=False,
                ),
                ipxe_script="string",
                is_pv_encryption_in_transit_enabled=False,
                launch_mode="string",
                launch_options=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsLaunchOptionsArgs(
                    boot_volume_type="string",
                    firmware="string",
                    is_consistent_volume_naming_enabled=False,
                    is_pv_encryption_in_transit_enabled=False,
                    network_type="string",
                    remote_data_volume_type="string",
                ),
                metadata={
                    "string": "any",
                },
                platform_config=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPlatformConfigArgs(
                    type="string",
                    are_virtual_instructions_enabled=False,
                    is_access_control_service_enabled=False,
                    is_input_output_memory_management_unit_enabled=False,
                    is_measured_boot_enabled=False,
                    is_memory_encryption_enabled=False,
                    is_secure_boot_enabled=False,
                    is_symmetric_multi_threading_enabled=False,
                    is_trusted_platform_module_enabled=False,
                    numa_nodes_per_socket="string",
                    percentage_of_cores_enabled=0,
                ),
                preemptible_instance_config=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigArgs(
                    preemption_action=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs(
                        type="string",
                        preserve_boot_volume=False,
                    ),
                ),
                preferred_maintenance_action="string",
                shape="string",
                shape_config=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsShapeConfigArgs(
                    baseline_ocpu_utilization="string",
                    memory_in_gbs=0,
                    nvmes=0,
                    ocpus=0,
                    vcpus=0,
                ),
                source_details=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsArgs(
                    source_type="string",
                    boot_volume_id="string",
                    boot_volume_size_in_gbs="string",
                    boot_volume_vpus_per_gb="string",
                    image_id="string",
                    instance_source_image_filter_details=oci.core.InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs(
                        compartment_id="string",
                        defined_tags_filter={
                            "string": "any",
                        },
                        operating_system="string",
                        operating_system_version="string",
                    ),
                    kms_key_id="string",
                ),
            ),
            secondary_vnics=[oci.core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicArgs(
                create_vnic_details=oci.core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsArgs(
                    assign_ipv6ip=False,
                    assign_private_dns_record=False,
                    assign_public_ip=False,
                    defined_tags={
                        "string": "any",
                    },
                    display_name="string",
                    freeform_tags={
                        "string": "any",
                    },
                    hostname_label="string",
                    ipv6address_ipv6subnet_cidr_pair_details=[oci.core.InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs(
                        ipv6address="string",
                        ipv6subnet_cidr="string",
                    )],
                    nsg_ids=["string"],
                    private_ip="string",
                    skip_source_dest_check=False,
                    subnet_id="string",
                ),
                display_name="string",
                nic_index=0,
            )],
        )],
        secondary_vnics=[oci.core.InstanceConfigurationInstanceDetailsSecondaryVnicArgs(
            create_vnic_details=oci.core.InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsArgs(
                assign_ipv6ip=False,
                assign_private_dns_record=False,
                assign_public_ip=False,
                defined_tags={
                    "string": "any",
                },
                display_name="string",
                freeform_tags={
                    "string": "any",
                },
                hostname_label="string",
                ipv6address_ipv6subnet_cidr_pair_details=[oci.core.InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs(
                    ipv6address="string",
                    ipv6subnet_cidr="string",
                )],
                nsg_ids=["string"],
                private_ip="string",
                skip_source_dest_check=False,
                subnet_id="string",
            ),
            display_name="string",
            nic_index=0,
        )],
    ),
    instance_id="string",
    source="string")
const instanceConfigurationResource = new oci.core.InstanceConfiguration("instanceConfigurationResource", {
    compartmentId: "string",
    definedTags: {
        string: "any",
    },
    displayName: "string",
    freeformTags: {
        string: "any",
    },
    instanceDetails: {
        instanceType: "string",
        blockVolumes: [{
            attachDetails: {
                type: "string",
                device: "string",
                displayName: "string",
                isPvEncryptionInTransitEnabled: false,
                isReadOnly: false,
                isShareable: false,
                useChap: false,
            },
            createDetails: {
                autotunePolicies: [{
                    autotuneType: "string",
                    maxVpusPerGb: "string",
                }],
                availabilityDomain: "string",
                backupPolicyId: "string",
                blockVolumeReplicas: {
                    availabilityDomain: "string",
                    displayName: "string",
                },
                clusterPlacementGroupId: "string",
                compartmentId: "string",
                definedTags: {
                    string: "any",
                },
                displayName: "string",
                freeformTags: {
                    string: "any",
                },
                isAutoTuneEnabled: false,
                kmsKeyId: "string",
                sizeInGbs: "string",
                sourceDetails: {
                    type: "string",
                    id: "string",
                },
                vpusPerGb: "string",
            },
            volumeId: "string",
        }],
        launchDetails: {
            agentConfig: {
                areAllPluginsDisabled: false,
                isManagementDisabled: false,
                isMonitoringDisabled: false,
                pluginsConfigs: [{
                    desiredState: "string",
                    name: "string",
                }],
            },
            availabilityConfig: {
                isLiveMigrationPreferred: false,
                recoveryAction: "string",
            },
            availabilityDomain: "string",
            capacityReservationId: "string",
            clusterPlacementGroupId: "string",
            compartmentId: "string",
            createVnicDetails: {
                assignIpv6ip: false,
                assignPrivateDnsRecord: false,
                assignPublicIp: false,
                definedTags: {
                    string: "any",
                },
                displayName: "string",
                freeformTags: {
                    string: "any",
                },
                hostnameLabel: "string",
                ipv6addressIpv6subnetCidrPairDetails: [{
                    ipv6address: "string",
                    ipv6subnetCidr: "string",
                }],
                nsgIds: ["string"],
                privateIp: "string",
                skipSourceDestCheck: false,
                subnetId: "string",
            },
            dedicatedVmHostId: "string",
            definedTags: {
                string: "any",
            },
            displayName: "string",
            extendedMetadata: {
                string: "any",
            },
            faultDomain: "string",
            freeformTags: {
                string: "any",
            },
            instanceOptions: {
                areLegacyImdsEndpointsDisabled: false,
            },
            ipxeScript: "string",
            isPvEncryptionInTransitEnabled: false,
            launchMode: "string",
            launchOptions: {
                bootVolumeType: "string",
                firmware: "string",
                isConsistentVolumeNamingEnabled: false,
                isPvEncryptionInTransitEnabled: false,
                networkType: "string",
                remoteDataVolumeType: "string",
            },
            metadata: {
                string: "any",
            },
            platformConfig: {
                type: "string",
                areVirtualInstructionsEnabled: false,
                configMap: {
                    string: "any",
                },
                isAccessControlServiceEnabled: false,
                isInputOutputMemoryManagementUnitEnabled: false,
                isMeasuredBootEnabled: false,
                isMemoryEncryptionEnabled: false,
                isSecureBootEnabled: false,
                isSymmetricMultiThreadingEnabled: false,
                isTrustedPlatformModuleEnabled: false,
                numaNodesPerSocket: "string",
                percentageOfCoresEnabled: 0,
            },
            preemptibleInstanceConfig: {
                preemptionAction: {
                    type: "string",
                    preserveBootVolume: false,
                },
            },
            preferredMaintenanceAction: "string",
            shape: "string",
            shapeConfig: {
                baselineOcpuUtilization: "string",
                memoryInGbs: 0,
                nvmes: 0,
                ocpus: 0,
                vcpus: 0,
            },
            sourceDetails: {
                sourceType: "string",
                bootVolumeId: "string",
                bootVolumeSizeInGbs: "string",
                bootVolumeVpusPerGb: "string",
                imageId: "string",
                instanceSourceImageFilterDetails: {
                    compartmentId: "string",
                    definedTagsFilter: {
                        string: "any",
                    },
                    operatingSystem: "string",
                    operatingSystemVersion: "string",
                },
                kmsKeyId: "string",
            },
        },
        options: [{
            blockVolumes: [{
                attachDetails: {
                    type: "string",
                    device: "string",
                    displayName: "string",
                    isPvEncryptionInTransitEnabled: false,
                    isReadOnly: false,
                    isShareable: false,
                    useChap: false,
                },
                createDetails: {
                    autotunePolicies: [{
                        autotuneType: "string",
                        maxVpusPerGb: "string",
                    }],
                    availabilityDomain: "string",
                    backupPolicyId: "string",
                    blockVolumeReplicas: {
                        availabilityDomain: "string",
                        displayName: "string",
                    },
                    clusterPlacementGroupId: "string",
                    compartmentId: "string",
                    definedTags: {
                        string: "any",
                    },
                    displayName: "string",
                    freeformTags: {
                        string: "any",
                    },
                    isAutoTuneEnabled: false,
                    kmsKeyId: "string",
                    sizeInGbs: "string",
                    sourceDetails: {
                        type: "string",
                        id: "string",
                    },
                    vpusPerGb: "string",
                },
                volumeId: "string",
            }],
            launchDetails: {
                agentConfig: {
                    areAllPluginsDisabled: false,
                    isManagementDisabled: false,
                    isMonitoringDisabled: false,
                    pluginsConfigs: [{
                        desiredState: "string",
                        name: "string",
                    }],
                },
                availabilityConfig: {
                    isLiveMigrationPreferred: false,
                    recoveryAction: "string",
                },
                availabilityDomain: "string",
                capacityReservationId: "string",
                clusterPlacementGroupId: "string",
                compartmentId: "string",
                createVnicDetails: {
                    assignIpv6ip: false,
                    assignPrivateDnsRecord: false,
                    assignPublicIp: false,
                    definedTags: {
                        string: "any",
                    },
                    displayName: "string",
                    freeformTags: {
                        string: "any",
                    },
                    hostnameLabel: "string",
                    ipv6addressIpv6subnetCidrPairDetails: [{
                        ipv6address: "string",
                        ipv6subnetCidr: "string",
                    }],
                    nsgIds: ["string"],
                    privateIp: "string",
                    skipSourceDestCheck: false,
                    subnetId: "string",
                },
                dedicatedVmHostId: "string",
                definedTags: {
                    string: "any",
                },
                displayName: "string",
                extendedMetadata: {
                    string: "any",
                },
                faultDomain: "string",
                freeformTags: {
                    string: "any",
                },
                instanceOptions: {
                    areLegacyImdsEndpointsDisabled: false,
                },
                ipxeScript: "string",
                isPvEncryptionInTransitEnabled: false,
                launchMode: "string",
                launchOptions: {
                    bootVolumeType: "string",
                    firmware: "string",
                    isConsistentVolumeNamingEnabled: false,
                    isPvEncryptionInTransitEnabled: false,
                    networkType: "string",
                    remoteDataVolumeType: "string",
                },
                metadata: {
                    string: "any",
                },
                platformConfig: {
                    type: "string",
                    areVirtualInstructionsEnabled: false,
                    isAccessControlServiceEnabled: false,
                    isInputOutputMemoryManagementUnitEnabled: false,
                    isMeasuredBootEnabled: false,
                    isMemoryEncryptionEnabled: false,
                    isSecureBootEnabled: false,
                    isSymmetricMultiThreadingEnabled: false,
                    isTrustedPlatformModuleEnabled: false,
                    numaNodesPerSocket: "string",
                    percentageOfCoresEnabled: 0,
                },
                preemptibleInstanceConfig: {
                    preemptionAction: {
                        type: "string",
                        preserveBootVolume: false,
                    },
                },
                preferredMaintenanceAction: "string",
                shape: "string",
                shapeConfig: {
                    baselineOcpuUtilization: "string",
                    memoryInGbs: 0,
                    nvmes: 0,
                    ocpus: 0,
                    vcpus: 0,
                },
                sourceDetails: {
                    sourceType: "string",
                    bootVolumeId: "string",
                    bootVolumeSizeInGbs: "string",
                    bootVolumeVpusPerGb: "string",
                    imageId: "string",
                    instanceSourceImageFilterDetails: {
                        compartmentId: "string",
                        definedTagsFilter: {
                            string: "any",
                        },
                        operatingSystem: "string",
                        operatingSystemVersion: "string",
                    },
                    kmsKeyId: "string",
                },
            },
            secondaryVnics: [{
                createVnicDetails: {
                    assignIpv6ip: false,
                    assignPrivateDnsRecord: false,
                    assignPublicIp: false,
                    definedTags: {
                        string: "any",
                    },
                    displayName: "string",
                    freeformTags: {
                        string: "any",
                    },
                    hostnameLabel: "string",
                    ipv6addressIpv6subnetCidrPairDetails: [{
                        ipv6address: "string",
                        ipv6subnetCidr: "string",
                    }],
                    nsgIds: ["string"],
                    privateIp: "string",
                    skipSourceDestCheck: false,
                    subnetId: "string",
                },
                displayName: "string",
                nicIndex: 0,
            }],
        }],
        secondaryVnics: [{
            createVnicDetails: {
                assignIpv6ip: false,
                assignPrivateDnsRecord: false,
                assignPublicIp: false,
                definedTags: {
                    string: "any",
                },
                displayName: "string",
                freeformTags: {
                    string: "any",
                },
                hostnameLabel: "string",
                ipv6addressIpv6subnetCidrPairDetails: [{
                    ipv6address: "string",
                    ipv6subnetCidr: "string",
                }],
                nsgIds: ["string"],
                privateIp: "string",
                skipSourceDestCheck: false,
                subnetId: "string",
            },
            displayName: "string",
            nicIndex: 0,
        }],
    },
    instanceId: "string",
    source: "string",
});
type: oci:Core:InstanceConfiguration
properties:
    compartmentId: string
    definedTags:
        string: any
    displayName: string
    freeformTags:
        string: any
    instanceDetails:
        blockVolumes:
            - attachDetails:
                device: string
                displayName: string
                isPvEncryptionInTransitEnabled: false
                isReadOnly: false
                isShareable: false
                type: string
                useChap: false
              createDetails:
                autotunePolicies:
                    - autotuneType: string
                      maxVpusPerGb: string
                availabilityDomain: string
                backupPolicyId: string
                blockVolumeReplicas:
                    availabilityDomain: string
                    displayName: string
                clusterPlacementGroupId: string
                compartmentId: string
                definedTags:
                    string: any
                displayName: string
                freeformTags:
                    string: any
                isAutoTuneEnabled: false
                kmsKeyId: string
                sizeInGbs: string
                sourceDetails:
                    id: string
                    type: string
                vpusPerGb: string
              volumeId: string
        instanceType: string
        launchDetails:
            agentConfig:
                areAllPluginsDisabled: false
                isManagementDisabled: false
                isMonitoringDisabled: false
                pluginsConfigs:
                    - desiredState: string
                      name: string
            availabilityConfig:
                isLiveMigrationPreferred: false
                recoveryAction: string
            availabilityDomain: string
            capacityReservationId: string
            clusterPlacementGroupId: string
            compartmentId: string
            createVnicDetails:
                assignIpv6ip: false
                assignPrivateDnsRecord: false
                assignPublicIp: false
                definedTags:
                    string: any
                displayName: string
                freeformTags:
                    string: any
                hostnameLabel: string
                ipv6addressIpv6subnetCidrPairDetails:
                    - ipv6address: string
                      ipv6subnetCidr: string
                nsgIds:
                    - string
                privateIp: string
                skipSourceDestCheck: false
                subnetId: string
            dedicatedVmHostId: string
            definedTags:
                string: any
            displayName: string
            extendedMetadata:
                string: any
            faultDomain: string
            freeformTags:
                string: any
            instanceOptions:
                areLegacyImdsEndpointsDisabled: false
            ipxeScript: string
            isPvEncryptionInTransitEnabled: false
            launchMode: string
            launchOptions:
                bootVolumeType: string
                firmware: string
                isConsistentVolumeNamingEnabled: false
                isPvEncryptionInTransitEnabled: false
                networkType: string
                remoteDataVolumeType: string
            metadata:
                string: any
            platformConfig:
                areVirtualInstructionsEnabled: false
                configMap:
                    string: any
                isAccessControlServiceEnabled: false
                isInputOutputMemoryManagementUnitEnabled: false
                isMeasuredBootEnabled: false
                isMemoryEncryptionEnabled: false
                isSecureBootEnabled: false
                isSymmetricMultiThreadingEnabled: false
                isTrustedPlatformModuleEnabled: false
                numaNodesPerSocket: string
                percentageOfCoresEnabled: 0
                type: string
            preemptibleInstanceConfig:
                preemptionAction:
                    preserveBootVolume: false
                    type: string
            preferredMaintenanceAction: string
            shape: string
            shapeConfig:
                baselineOcpuUtilization: string
                memoryInGbs: 0
                nvmes: 0
                ocpus: 0
                vcpus: 0
            sourceDetails:
                bootVolumeId: string
                bootVolumeSizeInGbs: string
                bootVolumeVpusPerGb: string
                imageId: string
                instanceSourceImageFilterDetails:
                    compartmentId: string
                    definedTagsFilter:
                        string: any
                    operatingSystem: string
                    operatingSystemVersion: string
                kmsKeyId: string
                sourceType: string
        options:
            - blockVolumes:
                - attachDetails:
                    device: string
                    displayName: string
                    isPvEncryptionInTransitEnabled: false
                    isReadOnly: false
                    isShareable: false
                    type: string
                    useChap: false
                  createDetails:
                    autotunePolicies:
                        - autotuneType: string
                          maxVpusPerGb: string
                    availabilityDomain: string
                    backupPolicyId: string
                    blockVolumeReplicas:
                        availabilityDomain: string
                        displayName: string
                    clusterPlacementGroupId: string
                    compartmentId: string
                    definedTags:
                        string: any
                    displayName: string
                    freeformTags:
                        string: any
                    isAutoTuneEnabled: false
                    kmsKeyId: string
                    sizeInGbs: string
                    sourceDetails:
                        id: string
                        type: string
                    vpusPerGb: string
                  volumeId: string
              launchDetails:
                agentConfig:
                    areAllPluginsDisabled: false
                    isManagementDisabled: false
                    isMonitoringDisabled: false
                    pluginsConfigs:
                        - desiredState: string
                          name: string
                availabilityConfig:
                    isLiveMigrationPreferred: false
                    recoveryAction: string
                availabilityDomain: string
                capacityReservationId: string
                clusterPlacementGroupId: string
                compartmentId: string
                createVnicDetails:
                    assignIpv6ip: false
                    assignPrivateDnsRecord: false
                    assignPublicIp: false
                    definedTags:
                        string: any
                    displayName: string
                    freeformTags:
                        string: any
                    hostnameLabel: string
                    ipv6addressIpv6subnetCidrPairDetails:
                        - ipv6address: string
                          ipv6subnetCidr: string
                    nsgIds:
                        - string
                    privateIp: string
                    skipSourceDestCheck: false
                    subnetId: string
                dedicatedVmHostId: string
                definedTags:
                    string: any
                displayName: string
                extendedMetadata:
                    string: any
                faultDomain: string
                freeformTags:
                    string: any
                instanceOptions:
                    areLegacyImdsEndpointsDisabled: false
                ipxeScript: string
                isPvEncryptionInTransitEnabled: false
                launchMode: string
                launchOptions:
                    bootVolumeType: string
                    firmware: string
                    isConsistentVolumeNamingEnabled: false
                    isPvEncryptionInTransitEnabled: false
                    networkType: string
                    remoteDataVolumeType: string
                metadata:
                    string: any
                platformConfig:
                    areVirtualInstructionsEnabled: false
                    isAccessControlServiceEnabled: false
                    isInputOutputMemoryManagementUnitEnabled: false
                    isMeasuredBootEnabled: false
                    isMemoryEncryptionEnabled: false
                    isSecureBootEnabled: false
                    isSymmetricMultiThreadingEnabled: false
                    isTrustedPlatformModuleEnabled: false
                    numaNodesPerSocket: string
                    percentageOfCoresEnabled: 0
                    type: string
                preemptibleInstanceConfig:
                    preemptionAction:
                        preserveBootVolume: false
                        type: string
                preferredMaintenanceAction: string
                shape: string
                shapeConfig:
                    baselineOcpuUtilization: string
                    memoryInGbs: 0
                    nvmes: 0
                    ocpus: 0
                    vcpus: 0
                sourceDetails:
                    bootVolumeId: string
                    bootVolumeSizeInGbs: string
                    bootVolumeVpusPerGb: string
                    imageId: string
                    instanceSourceImageFilterDetails:
                        compartmentId: string
                        definedTagsFilter:
                            string: any
                        operatingSystem: string
                        operatingSystemVersion: string
                    kmsKeyId: string
                    sourceType: string
              secondaryVnics:
                - createVnicDetails:
                    assignIpv6ip: false
                    assignPrivateDnsRecord: false
                    assignPublicIp: false
                    definedTags:
                        string: any
                    displayName: string
                    freeformTags:
                        string: any
                    hostnameLabel: string
                    ipv6addressIpv6subnetCidrPairDetails:
                        - ipv6address: string
                          ipv6subnetCidr: string
                    nsgIds:
                        - string
                    privateIp: string
                    skipSourceDestCheck: false
                    subnetId: string
                  displayName: string
                  nicIndex: 0
        secondaryVnics:
            - createVnicDetails:
                assignIpv6ip: false
                assignPrivateDnsRecord: false
                assignPublicIp: false
                definedTags:
                    string: any
                displayName: string
                freeformTags:
                    string: any
                hostnameLabel: string
                ipv6addressIpv6subnetCidrPairDetails:
                    - ipv6address: string
                      ipv6subnetCidr: string
                nsgIds:
                    - string
                privateIp: string
                skipSourceDestCheck: false
                subnetId: string
              displayName: string
              nicIndex: 0
    instanceId: string
    source: string
InstanceConfiguration Resource Properties
To learn more about resource properties and how to use them, see Inputs and Outputs in the Architecture and Concepts docs.
Inputs
The InstanceConfiguration resource accepts the following input properties:
- CompartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- Dictionary<string, object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Dictionary<string, object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- InstanceDetails InstanceConfiguration Instance Details 
- InstanceId string
- The OCID of the instance to use to create the instance configuration.
- Source string
- The source of the instance configuration. An instance configuration defines the settings to use when creating Compute instances, including details such as the base image, shape, and metadata. You can also specify the associated resources for the instance, such as block volume attachments and network configuration. - When you create an instance configuration using an existing instance as a template, the instance configuration does not include any information from the source instance's boot volume, such as installed applications, binaries, and files on the instance. It also does not include the contents of any block volumes that are attached to the instance. - To create an instance configuration that includes the custom setup from an instance's boot volume, you must first create a custom image from the instance (see CreateImage). Then, use the custom image to launch a new instance (see LaunchInstance). Finally, create the instance configuration based on the instance that you created from the custom image. - To include block volume contents with an instance configuration, first create a backup of the attached block volumes (see CreateVolumeBackup). Then, create the instance configuration by specifying the list of settings, using InstanceConfigurationVolumeSourceFromVolumeBackupDetails to include the block volume backups in the list of settings. - The following values are supported: - NONE: Creates an instance configuration using the list of settings that you specify.
- INSTANCE: Creates an instance configuration using an existing instance as a template.
 - ** IMPORTANT ** Any change to a property that does not support update will force the destruction and recreation of the resource with the new property values 
- CompartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- map[string]interface{}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- map[string]interface{}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- InstanceDetails InstanceConfiguration Instance Details Args 
- InstanceId string
- The OCID of the instance to use to create the instance configuration.
- Source string
- The source of the instance configuration. An instance configuration defines the settings to use when creating Compute instances, including details such as the base image, shape, and metadata. You can also specify the associated resources for the instance, such as block volume attachments and network configuration. - When you create an instance configuration using an existing instance as a template, the instance configuration does not include any information from the source instance's boot volume, such as installed applications, binaries, and files on the instance. It also does not include the contents of any block volumes that are attached to the instance. - To create an instance configuration that includes the custom setup from an instance's boot volume, you must first create a custom image from the instance (see CreateImage). Then, use the custom image to launch a new instance (see LaunchInstance). Finally, create the instance configuration based on the instance that you created from the custom image. - To include block volume contents with an instance configuration, first create a backup of the attached block volumes (see CreateVolumeBackup). Then, create the instance configuration by specifying the list of settings, using InstanceConfigurationVolumeSourceFromVolumeBackupDetails to include the block volume backups in the list of settings. - The following values are supported: - NONE: Creates an instance configuration using the list of settings that you specify.
- INSTANCE: Creates an instance configuration using an existing instance as a template.
 - ** IMPORTANT ** Any change to a property that does not support update will force the destruction and recreation of the resource with the new property values 
- compartmentId String
- (Updatable) The OCID of the compartment containing the instance configuration.
- Map<String,Object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<String,Object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instanceDetails InstanceConfiguration Instance Details 
- instanceId String
- The OCID of the instance to use to create the instance configuration.
- source String
- The source of the instance configuration. An instance configuration defines the settings to use when creating Compute instances, including details such as the base image, shape, and metadata. You can also specify the associated resources for the instance, such as block volume attachments and network configuration. - When you create an instance configuration using an existing instance as a template, the instance configuration does not include any information from the source instance's boot volume, such as installed applications, binaries, and files on the instance. It also does not include the contents of any block volumes that are attached to the instance. - To create an instance configuration that includes the custom setup from an instance's boot volume, you must first create a custom image from the instance (see CreateImage). Then, use the custom image to launch a new instance (see LaunchInstance). Finally, create the instance configuration based on the instance that you created from the custom image. - To include block volume contents with an instance configuration, first create a backup of the attached block volumes (see CreateVolumeBackup). Then, create the instance configuration by specifying the list of settings, using InstanceConfigurationVolumeSourceFromVolumeBackupDetails to include the block volume backups in the list of settings. - The following values are supported: - NONE: Creates an instance configuration using the list of settings that you specify.
- INSTANCE: Creates an instance configuration using an existing instance as a template.
 - ** IMPORTANT ** Any change to a property that does not support update will force the destruction and recreation of the resource with the new property values 
- compartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- {[key: string]: any}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- {[key: string]: any}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instanceDetails InstanceConfiguration Instance Details 
- instanceId string
- The OCID of the instance to use to create the instance configuration.
- source string
- The source of the instance configuration. An instance configuration defines the settings to use when creating Compute instances, including details such as the base image, shape, and metadata. You can also specify the associated resources for the instance, such as block volume attachments and network configuration. - When you create an instance configuration using an existing instance as a template, the instance configuration does not include any information from the source instance's boot volume, such as installed applications, binaries, and files on the instance. It also does not include the contents of any block volumes that are attached to the instance. - To create an instance configuration that includes the custom setup from an instance's boot volume, you must first create a custom image from the instance (see CreateImage). Then, use the custom image to launch a new instance (see LaunchInstance). Finally, create the instance configuration based on the instance that you created from the custom image. - To include block volume contents with an instance configuration, first create a backup of the attached block volumes (see CreateVolumeBackup). Then, create the instance configuration by specifying the list of settings, using InstanceConfigurationVolumeSourceFromVolumeBackupDetails to include the block volume backups in the list of settings. - The following values are supported: - NONE: Creates an instance configuration using the list of settings that you specify.
- INSTANCE: Creates an instance configuration using an existing instance as a template.
 - ** IMPORTANT ** Any change to a property that does not support update will force the destruction and recreation of the resource with the new property values 
- compartment_id str
- (Updatable) The OCID of the compartment containing the instance configuration.
- Mapping[str, Any]
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- display_name str
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Mapping[str, Any]
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instance_details core.Instance Configuration Instance Details Args 
- instance_id str
- The OCID of the instance to use to create the instance configuration.
- source str
- The source of the instance configuration. An instance configuration defines the settings to use when creating Compute instances, including details such as the base image, shape, and metadata. You can also specify the associated resources for the instance, such as block volume attachments and network configuration. - When you create an instance configuration using an existing instance as a template, the instance configuration does not include any information from the source instance's boot volume, such as installed applications, binaries, and files on the instance. It also does not include the contents of any block volumes that are attached to the instance. - To create an instance configuration that includes the custom setup from an instance's boot volume, you must first create a custom image from the instance (see CreateImage). Then, use the custom image to launch a new instance (see LaunchInstance). Finally, create the instance configuration based on the instance that you created from the custom image. - To include block volume contents with an instance configuration, first create a backup of the attached block volumes (see CreateVolumeBackup). Then, create the instance configuration by specifying the list of settings, using InstanceConfigurationVolumeSourceFromVolumeBackupDetails to include the block volume backups in the list of settings. - The following values are supported: - NONE: Creates an instance configuration using the list of settings that you specify.
- INSTANCE: Creates an instance configuration using an existing instance as a template.
 - ** IMPORTANT ** Any change to a property that does not support update will force the destruction and recreation of the resource with the new property values 
- compartmentId String
- (Updatable) The OCID of the compartment containing the instance configuration.
- Map<Any>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<Any>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instanceDetails Property Map
- instanceId String
- The OCID of the instance to use to create the instance configuration.
- source String
- The source of the instance configuration. An instance configuration defines the settings to use when creating Compute instances, including details such as the base image, shape, and metadata. You can also specify the associated resources for the instance, such as block volume attachments and network configuration. - When you create an instance configuration using an existing instance as a template, the instance configuration does not include any information from the source instance's boot volume, such as installed applications, binaries, and files on the instance. It also does not include the contents of any block volumes that are attached to the instance. - To create an instance configuration that includes the custom setup from an instance's boot volume, you must first create a custom image from the instance (see CreateImage). Then, use the custom image to launch a new instance (see LaunchInstance). Finally, create the instance configuration based on the instance that you created from the custom image. - To include block volume contents with an instance configuration, first create a backup of the attached block volumes (see CreateVolumeBackup). Then, create the instance configuration by specifying the list of settings, using InstanceConfigurationVolumeSourceFromVolumeBackupDetails to include the block volume backups in the list of settings. - The following values are supported: - NONE: Creates an instance configuration using the list of settings that you specify.
- INSTANCE: Creates an instance configuration using an existing instance as a template.
 - ** IMPORTANT ** Any change to a property that does not support update will force the destruction and recreation of the resource with the new property values 
Outputs
All input properties are implicitly available as output properties. Additionally, the InstanceConfiguration resource produces the following output properties:
- DeferredFields List<string>
- Parameters that were not specified when the instance configuration was created, but that are required to launch an instance from the instance configuration. See the LaunchInstanceConfiguration operation.
- Id string
- The provider-assigned unique ID for this managed resource.
- TimeCreated string
- The date and time the instance configuration was created, in the format defined by RFC3339. Example: 2016-08-25T21:10:29.600Z
- DeferredFields []string
- Parameters that were not specified when the instance configuration was created, but that are required to launch an instance from the instance configuration. See the LaunchInstanceConfiguration operation.
- Id string
- The provider-assigned unique ID for this managed resource.
- TimeCreated string
- The date and time the instance configuration was created, in the format defined by RFC3339. Example: 2016-08-25T21:10:29.600Z
- deferredFields List<String>
- Parameters that were not specified when the instance configuration was created, but that are required to launch an instance from the instance configuration. See the LaunchInstanceConfiguration operation.
- id String
- The provider-assigned unique ID for this managed resource.
- timeCreated String
- The date and time the instance configuration was created, in the format defined by RFC3339. Example: 2016-08-25T21:10:29.600Z
- deferredFields string[]
- Parameters that were not specified when the instance configuration was created, but that are required to launch an instance from the instance configuration. See the LaunchInstanceConfiguration operation.
- id string
- The provider-assigned unique ID for this managed resource.
- timeCreated string
- The date and time the instance configuration was created, in the format defined by RFC3339. Example: 2016-08-25T21:10:29.600Z
- deferred_fields Sequence[str]
- Parameters that were not specified when the instance configuration was created, but that are required to launch an instance from the instance configuration. See the LaunchInstanceConfiguration operation.
- id str
- The provider-assigned unique ID for this managed resource.
- time_created str
- The date and time the instance configuration was created, in the format defined by RFC3339. Example: 2016-08-25T21:10:29.600Z
- deferredFields List<String>
- Parameters that were not specified when the instance configuration was created, but that are required to launch an instance from the instance configuration. See the LaunchInstanceConfiguration operation.
- id String
- The provider-assigned unique ID for this managed resource.
- timeCreated String
- The date and time the instance configuration was created, in the format defined by RFC3339. Example: 2016-08-25T21:10:29.600Z
Look up Existing InstanceConfiguration Resource
Get an existing InstanceConfiguration resource’s state with the given name, ID, and optional extra properties used to qualify the lookup.
public static get(name: string, id: Input<ID>, state?: InstanceConfigurationState, opts?: CustomResourceOptions): InstanceConfiguration@staticmethod
def get(resource_name: str,
        id: str,
        opts: Optional[ResourceOptions] = None,
        compartment_id: Optional[str] = None,
        deferred_fields: Optional[Sequence[str]] = None,
        defined_tags: Optional[Mapping[str, Any]] = None,
        display_name: Optional[str] = None,
        freeform_tags: Optional[Mapping[str, Any]] = None,
        instance_details: Optional[_core.InstanceConfigurationInstanceDetailsArgs] = None,
        instance_id: Optional[str] = None,
        source: Optional[str] = None,
        time_created: Optional[str] = None) -> InstanceConfigurationfunc GetInstanceConfiguration(ctx *Context, name string, id IDInput, state *InstanceConfigurationState, opts ...ResourceOption) (*InstanceConfiguration, error)public static InstanceConfiguration Get(string name, Input<string> id, InstanceConfigurationState? state, CustomResourceOptions? opts = null)public static InstanceConfiguration get(String name, Output<String> id, InstanceConfigurationState state, CustomResourceOptions options)Resource lookup is not supported in YAML- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- resource_name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- CompartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- DeferredFields List<string>
- Parameters that were not specified when the instance configuration was created, but that are required to launch an instance from the instance configuration. See the LaunchInstanceConfiguration operation.
- Dictionary<string, object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Dictionary<string, object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- InstanceDetails InstanceConfiguration Instance Details 
- InstanceId string
- The OCID of the instance to use to create the instance configuration.
- Source string
- The source of the instance configuration. An instance configuration defines the settings to use when creating Compute instances, including details such as the base image, shape, and metadata. You can also specify the associated resources for the instance, such as block volume attachments and network configuration. - When you create an instance configuration using an existing instance as a template, the instance configuration does not include any information from the source instance's boot volume, such as installed applications, binaries, and files on the instance. It also does not include the contents of any block volumes that are attached to the instance. - To create an instance configuration that includes the custom setup from an instance's boot volume, you must first create a custom image from the instance (see CreateImage). Then, use the custom image to launch a new instance (see LaunchInstance). Finally, create the instance configuration based on the instance that you created from the custom image. - To include block volume contents with an instance configuration, first create a backup of the attached block volumes (see CreateVolumeBackup). Then, create the instance configuration by specifying the list of settings, using InstanceConfigurationVolumeSourceFromVolumeBackupDetails to include the block volume backups in the list of settings. - The following values are supported: - NONE: Creates an instance configuration using the list of settings that you specify.
- INSTANCE: Creates an instance configuration using an existing instance as a template.
 - ** IMPORTANT ** Any change to a property that does not support update will force the destruction and recreation of the resource with the new property values 
- TimeCreated string
- The date and time the instance configuration was created, in the format defined by RFC3339. Example: 2016-08-25T21:10:29.600Z
- CompartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- DeferredFields []string
- Parameters that were not specified when the instance configuration was created, but that are required to launch an instance from the instance configuration. See the LaunchInstanceConfiguration operation.
- map[string]interface{}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- map[string]interface{}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- InstanceDetails InstanceConfiguration Instance Details Args 
- InstanceId string
- The OCID of the instance to use to create the instance configuration.
- Source string
- The source of the instance configuration. An instance configuration defines the settings to use when creating Compute instances, including details such as the base image, shape, and metadata. You can also specify the associated resources for the instance, such as block volume attachments and network configuration. - When you create an instance configuration using an existing instance as a template, the instance configuration does not include any information from the source instance's boot volume, such as installed applications, binaries, and files on the instance. It also does not include the contents of any block volumes that are attached to the instance. - To create an instance configuration that includes the custom setup from an instance's boot volume, you must first create a custom image from the instance (see CreateImage). Then, use the custom image to launch a new instance (see LaunchInstance). Finally, create the instance configuration based on the instance that you created from the custom image. - To include block volume contents with an instance configuration, first create a backup of the attached block volumes (see CreateVolumeBackup). Then, create the instance configuration by specifying the list of settings, using InstanceConfigurationVolumeSourceFromVolumeBackupDetails to include the block volume backups in the list of settings. - The following values are supported: - NONE: Creates an instance configuration using the list of settings that you specify.
- INSTANCE: Creates an instance configuration using an existing instance as a template.
 - ** IMPORTANT ** Any change to a property that does not support update will force the destruction and recreation of the resource with the new property values 
- TimeCreated string
- The date and time the instance configuration was created, in the format defined by RFC3339. Example: 2016-08-25T21:10:29.600Z
- compartmentId String
- (Updatable) The OCID of the compartment containing the instance configuration.
- deferredFields List<String>
- Parameters that were not specified when the instance configuration was created, but that are required to launch an instance from the instance configuration. See the LaunchInstanceConfiguration operation.
- Map<String,Object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<String,Object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instanceDetails InstanceConfiguration Instance Details 
- instanceId String
- The OCID of the instance to use to create the instance configuration.
- source String
- The source of the instance configuration. An instance configuration defines the settings to use when creating Compute instances, including details such as the base image, shape, and metadata. You can also specify the associated resources for the instance, such as block volume attachments and network configuration. - When you create an instance configuration using an existing instance as a template, the instance configuration does not include any information from the source instance's boot volume, such as installed applications, binaries, and files on the instance. It also does not include the contents of any block volumes that are attached to the instance. - To create an instance configuration that includes the custom setup from an instance's boot volume, you must first create a custom image from the instance (see CreateImage). Then, use the custom image to launch a new instance (see LaunchInstance). Finally, create the instance configuration based on the instance that you created from the custom image. - To include block volume contents with an instance configuration, first create a backup of the attached block volumes (see CreateVolumeBackup). Then, create the instance configuration by specifying the list of settings, using InstanceConfigurationVolumeSourceFromVolumeBackupDetails to include the block volume backups in the list of settings. - The following values are supported: - NONE: Creates an instance configuration using the list of settings that you specify.
- INSTANCE: Creates an instance configuration using an existing instance as a template.
 - ** IMPORTANT ** Any change to a property that does not support update will force the destruction and recreation of the resource with the new property values 
- timeCreated String
- The date and time the instance configuration was created, in the format defined by RFC3339. Example: 2016-08-25T21:10:29.600Z
- compartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- deferredFields string[]
- Parameters that were not specified when the instance configuration was created, but that are required to launch an instance from the instance configuration. See the LaunchInstanceConfiguration operation.
- {[key: string]: any}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- {[key: string]: any}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instanceDetails InstanceConfiguration Instance Details 
- instanceId string
- The OCID of the instance to use to create the instance configuration.
- source string
- The source of the instance configuration. An instance configuration defines the settings to use when creating Compute instances, including details such as the base image, shape, and metadata. You can also specify the associated resources for the instance, such as block volume attachments and network configuration. - When you create an instance configuration using an existing instance as a template, the instance configuration does not include any information from the source instance's boot volume, such as installed applications, binaries, and files on the instance. It also does not include the contents of any block volumes that are attached to the instance. - To create an instance configuration that includes the custom setup from an instance's boot volume, you must first create a custom image from the instance (see CreateImage). Then, use the custom image to launch a new instance (see LaunchInstance). Finally, create the instance configuration based on the instance that you created from the custom image. - To include block volume contents with an instance configuration, first create a backup of the attached block volumes (see CreateVolumeBackup). Then, create the instance configuration by specifying the list of settings, using InstanceConfigurationVolumeSourceFromVolumeBackupDetails to include the block volume backups in the list of settings. - The following values are supported: - NONE: Creates an instance configuration using the list of settings that you specify.
- INSTANCE: Creates an instance configuration using an existing instance as a template.
 - ** IMPORTANT ** Any change to a property that does not support update will force the destruction and recreation of the resource with the new property values 
- timeCreated string
- The date and time the instance configuration was created, in the format defined by RFC3339. Example: 2016-08-25T21:10:29.600Z
- compartment_id str
- (Updatable) The OCID of the compartment containing the instance configuration.
- deferred_fields Sequence[str]
- Parameters that were not specified when the instance configuration was created, but that are required to launch an instance from the instance configuration. See the LaunchInstanceConfiguration operation.
- Mapping[str, Any]
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- display_name str
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Mapping[str, Any]
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instance_details core.Instance Configuration Instance Details Args 
- instance_id str
- The OCID of the instance to use to create the instance configuration.
- source str
- The source of the instance configuration. An instance configuration defines the settings to use when creating Compute instances, including details such as the base image, shape, and metadata. You can also specify the associated resources for the instance, such as block volume attachments and network configuration. - When you create an instance configuration using an existing instance as a template, the instance configuration does not include any information from the source instance's boot volume, such as installed applications, binaries, and files on the instance. It also does not include the contents of any block volumes that are attached to the instance. - To create an instance configuration that includes the custom setup from an instance's boot volume, you must first create a custom image from the instance (see CreateImage). Then, use the custom image to launch a new instance (see LaunchInstance). Finally, create the instance configuration based on the instance that you created from the custom image. - To include block volume contents with an instance configuration, first create a backup of the attached block volumes (see CreateVolumeBackup). Then, create the instance configuration by specifying the list of settings, using InstanceConfigurationVolumeSourceFromVolumeBackupDetails to include the block volume backups in the list of settings. - The following values are supported: - NONE: Creates an instance configuration using the list of settings that you specify.
- INSTANCE: Creates an instance configuration using an existing instance as a template.
 - ** IMPORTANT ** Any change to a property that does not support update will force the destruction and recreation of the resource with the new property values 
- time_created str
- The date and time the instance configuration was created, in the format defined by RFC3339. Example: 2016-08-25T21:10:29.600Z
- compartmentId String
- (Updatable) The OCID of the compartment containing the instance configuration.
- deferredFields List<String>
- Parameters that were not specified when the instance configuration was created, but that are required to launch an instance from the instance configuration. See the LaunchInstanceConfiguration operation.
- Map<Any>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<Any>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instanceDetails Property Map
- instanceId String
- The OCID of the instance to use to create the instance configuration.
- source String
- The source of the instance configuration. An instance configuration defines the settings to use when creating Compute instances, including details such as the base image, shape, and metadata. You can also specify the associated resources for the instance, such as block volume attachments and network configuration. - When you create an instance configuration using an existing instance as a template, the instance configuration does not include any information from the source instance's boot volume, such as installed applications, binaries, and files on the instance. It also does not include the contents of any block volumes that are attached to the instance. - To create an instance configuration that includes the custom setup from an instance's boot volume, you must first create a custom image from the instance (see CreateImage). Then, use the custom image to launch a new instance (see LaunchInstance). Finally, create the instance configuration based on the instance that you created from the custom image. - To include block volume contents with an instance configuration, first create a backup of the attached block volumes (see CreateVolumeBackup). Then, create the instance configuration by specifying the list of settings, using InstanceConfigurationVolumeSourceFromVolumeBackupDetails to include the block volume backups in the list of settings. - The following values are supported: - NONE: Creates an instance configuration using the list of settings that you specify.
- INSTANCE: Creates an instance configuration using an existing instance as a template.
 - ** IMPORTANT ** Any change to a property that does not support update will force the destruction and recreation of the resource with the new property values 
- timeCreated String
- The date and time the instance configuration was created, in the format defined by RFC3339. Example: 2016-08-25T21:10:29.600Z
Supporting Types
InstanceConfigurationInstanceDetails, InstanceConfigurationInstanceDetailsArgs        
- InstanceType string
- The type of instance details. Supported instanceType is compute
- BlockVolumes List<InstanceConfiguration Instance Details Block Volume> 
- Block volume parameters.
- LaunchDetails InstanceConfiguration Instance Details Launch Details 
- Instance launch details for creating an instance from an instance configuration. Use the - sourceDetailsparameter to specify whether a boot volume or an image should be used to launch a new instance.- See LaunchInstanceDetails for more information. 
- Options
List<InstanceConfiguration Instance Details Option> 
- Multiple Compute Instance Configuration instance details.
- SecondaryVnics List<InstanceConfiguration Instance Details Secondary Vnic> 
- Secondary VNIC parameters.
- InstanceType string
- The type of instance details. Supported instanceType is compute
- BlockVolumes []InstanceConfiguration Instance Details Block Volume 
- Block volume parameters.
- LaunchDetails InstanceConfiguration Instance Details Launch Details 
- Instance launch details for creating an instance from an instance configuration. Use the - sourceDetailsparameter to specify whether a boot volume or an image should be used to launch a new instance.- See LaunchInstanceDetails for more information. 
- Options
[]InstanceConfiguration Instance Details Option 
- Multiple Compute Instance Configuration instance details.
- SecondaryVnics []InstanceConfiguration Instance Details Secondary Vnic 
- Secondary VNIC parameters.
- instanceType String
- The type of instance details. Supported instanceType is compute
- blockVolumes List<InstanceConfiguration Instance Details Block Volume> 
- Block volume parameters.
- launchDetails InstanceConfiguration Instance Details Launch Details 
- Instance launch details for creating an instance from an instance configuration. Use the - sourceDetailsparameter to specify whether a boot volume or an image should be used to launch a new instance.- See LaunchInstanceDetails for more information. 
- options
List<InstanceConfiguration Instance Details Option> 
- Multiple Compute Instance Configuration instance details.
- secondaryVnics List<InstanceConfiguration Instance Details Secondary Vnic> 
- Secondary VNIC parameters.
- instanceType string
- The type of instance details. Supported instanceType is compute
- blockVolumes InstanceConfiguration Instance Details Block Volume[] 
- Block volume parameters.
- launchDetails InstanceConfiguration Instance Details Launch Details 
- Instance launch details for creating an instance from an instance configuration. Use the - sourceDetailsparameter to specify whether a boot volume or an image should be used to launch a new instance.- See LaunchInstanceDetails for more information. 
- options
InstanceConfiguration Instance Details Option[] 
- Multiple Compute Instance Configuration instance details.
- secondaryVnics InstanceConfiguration Instance Details Secondary Vnic[] 
- Secondary VNIC parameters.
- instance_type str
- The type of instance details. Supported instanceType is compute
- block_volumes Sequence[core.Instance Configuration Instance Details Block Volume] 
- Block volume parameters.
- launch_details core.Instance Configuration Instance Details Launch Details 
- Instance launch details for creating an instance from an instance configuration. Use the - sourceDetailsparameter to specify whether a boot volume or an image should be used to launch a new instance.- See LaunchInstanceDetails for more information. 
- options
Sequence[core.Instance Configuration Instance Details Option] 
- Multiple Compute Instance Configuration instance details.
- secondary_vnics Sequence[core.Instance Configuration Instance Details Secondary Vnic] 
- Secondary VNIC parameters.
- instanceType String
- The type of instance details. Supported instanceType is compute
- blockVolumes List<Property Map>
- Block volume parameters.
- launchDetails Property Map
- Instance launch details for creating an instance from an instance configuration. Use the - sourceDetailsparameter to specify whether a boot volume or an image should be used to launch a new instance.- See LaunchInstanceDetails for more information. 
- options List<Property Map>
- Multiple Compute Instance Configuration instance details.
- secondaryVnics List<Property Map>
- Secondary VNIC parameters.
InstanceConfigurationInstanceDetailsBlockVolume, InstanceConfigurationInstanceDetailsBlockVolumeArgs            
- AttachDetails InstanceConfiguration Instance Details Block Volume Attach Details 
- Volume attachmentDetails. Please see AttachVolumeDetails
- CreateDetails InstanceConfiguration Instance Details Block Volume Create Details 
- Creates a new block volume. Please see CreateVolumeDetails
- VolumeId string
- The OCID of the volume.
- AttachDetails InstanceConfiguration Instance Details Block Volume Attach Details 
- Volume attachmentDetails. Please see AttachVolumeDetails
- CreateDetails InstanceConfiguration Instance Details Block Volume Create Details 
- Creates a new block volume. Please see CreateVolumeDetails
- VolumeId string
- The OCID of the volume.
- attachDetails InstanceConfiguration Instance Details Block Volume Attach Details 
- Volume attachmentDetails. Please see AttachVolumeDetails
- createDetails InstanceConfiguration Instance Details Block Volume Create Details 
- Creates a new block volume. Please see CreateVolumeDetails
- volumeId String
- The OCID of the volume.
- attachDetails InstanceConfiguration Instance Details Block Volume Attach Details 
- Volume attachmentDetails. Please see AttachVolumeDetails
- createDetails InstanceConfiguration Instance Details Block Volume Create Details 
- Creates a new block volume. Please see CreateVolumeDetails
- volumeId string
- The OCID of the volume.
- attach_details core.Instance Configuration Instance Details Block Volume Attach Details 
- Volume attachmentDetails. Please see AttachVolumeDetails
- create_details core.Instance Configuration Instance Details Block Volume Create Details 
- Creates a new block volume. Please see CreateVolumeDetails
- volume_id str
- The OCID of the volume.
- attachDetails Property Map
- Volume attachmentDetails. Please see AttachVolumeDetails
- createDetails Property Map
- Creates a new block volume. Please see CreateVolumeDetails
- volumeId String
- The OCID of the volume.
InstanceConfigurationInstanceDetailsBlockVolumeAttachDetails, InstanceConfigurationInstanceDetailsBlockVolumeAttachDetailsArgs                
- Type string
- The type of volume. The only supported values are "iscsi" and "paravirtualized".
- Device string
- The device name.
- DisplayName string
- A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- IsPv boolEncryption In Transit Enabled 
- Whether to enable in-transit encryption for the data volume's paravirtualized attachment. The default value is false.
- IsRead boolOnly 
- Whether the attachment should be created in read-only mode.
- bool
- Whether the attachment should be created in shareable mode. If an attachment is created in shareable mode, then other instances can attach the same volume, provided that they also create their attachments in shareable mode. Only certain volume types can be attached in shareable mode. Defaults to false if not specified.
- UseChap bool
- Whether to use CHAP authentication for the volume attachment. Defaults to false.
- Type string
- The type of volume. The only supported values are "iscsi" and "paravirtualized".
- Device string
- The device name.
- DisplayName string
- A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- IsPv boolEncryption In Transit Enabled 
- Whether to enable in-transit encryption for the data volume's paravirtualized attachment. The default value is false.
- IsRead boolOnly 
- Whether the attachment should be created in read-only mode.
- bool
- Whether the attachment should be created in shareable mode. If an attachment is created in shareable mode, then other instances can attach the same volume, provided that they also create their attachments in shareable mode. Only certain volume types can be attached in shareable mode. Defaults to false if not specified.
- UseChap bool
- Whether to use CHAP authentication for the volume attachment. Defaults to false.
- type String
- The type of volume. The only supported values are "iscsi" and "paravirtualized".
- device String
- The device name.
- displayName String
- A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- isPv BooleanEncryption In Transit Enabled 
- Whether to enable in-transit encryption for the data volume's paravirtualized attachment. The default value is false.
- isRead BooleanOnly 
- Whether the attachment should be created in read-only mode.
- Boolean
- Whether the attachment should be created in shareable mode. If an attachment is created in shareable mode, then other instances can attach the same volume, provided that they also create their attachments in shareable mode. Only certain volume types can be attached in shareable mode. Defaults to false if not specified.
- useChap Boolean
- Whether to use CHAP authentication for the volume attachment. Defaults to false.
- type string
- The type of volume. The only supported values are "iscsi" and "paravirtualized".
- device string
- The device name.
- displayName string
- A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- isPv booleanEncryption In Transit Enabled 
- Whether to enable in-transit encryption for the data volume's paravirtualized attachment. The default value is false.
- isRead booleanOnly 
- Whether the attachment should be created in read-only mode.
- boolean
- Whether the attachment should be created in shareable mode. If an attachment is created in shareable mode, then other instances can attach the same volume, provided that they also create their attachments in shareable mode. Only certain volume types can be attached in shareable mode. Defaults to false if not specified.
- useChap boolean
- Whether to use CHAP authentication for the volume attachment. Defaults to false.
- type str
- The type of volume. The only supported values are "iscsi" and "paravirtualized".
- device str
- The device name.
- display_name str
- A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- is_pv_ boolencryption_ in_ transit_ enabled 
- Whether to enable in-transit encryption for the data volume's paravirtualized attachment. The default value is false.
- is_read_ boolonly 
- Whether the attachment should be created in read-only mode.
- bool
- Whether the attachment should be created in shareable mode. If an attachment is created in shareable mode, then other instances can attach the same volume, provided that they also create their attachments in shareable mode. Only certain volume types can be attached in shareable mode. Defaults to false if not specified.
- use_chap bool
- Whether to use CHAP authentication for the volume attachment. Defaults to false.
- type String
- The type of volume. The only supported values are "iscsi" and "paravirtualized".
- device String
- The device name.
- displayName String
- A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- isPv BooleanEncryption In Transit Enabled 
- Whether to enable in-transit encryption for the data volume's paravirtualized attachment. The default value is false.
- isRead BooleanOnly 
- Whether the attachment should be created in read-only mode.
- Boolean
- Whether the attachment should be created in shareable mode. If an attachment is created in shareable mode, then other instances can attach the same volume, provided that they also create their attachments in shareable mode. Only certain volume types can be attached in shareable mode. Defaults to false if not specified.
- useChap Boolean
- Whether to use CHAP authentication for the volume attachment. Defaults to false.
InstanceConfigurationInstanceDetailsBlockVolumeCreateDetails, InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsArgs                
- AutotunePolicies List<InstanceConfiguration Instance Details Block Volume Create Details Autotune Policy> 
- The list of autotune policies enabled for this volume.
- AvailabilityDomain string
- The availability domain of the volume. Example: Uocm:PHX-AD-1
- BackupPolicy stringId 
- If provided, specifies the ID of the volume backup policy to assign to the newly created volume. If omitted, no policy will be assigned.
- BlockVolume InstanceReplicas Configuration Instance Details Block Volume Create Details Block Volume Replicas 
- The list of block volume replicas to be enabled for this volume in the specified destination availability domains.
- ClusterPlacement stringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- CompartmentId string
- The OCID of the compartment that contains the volume.
- Dictionary<string, object>
- Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Dictionary<string, object>
- Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- IsAuto boolTune Enabled 
- Specifies whether the auto-tune performance is enabled for this boot volume. This field is deprecated. Use the InstanceConfigurationDetachedVolumeAutotunePolicyinstead to enable the volume for detached autotune.
- KmsKey stringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- SizeIn stringGbs 
- The size of the volume in GBs.
- SourceDetails InstanceConfiguration Instance Details Block Volume Create Details Source Details 
- VpusPer stringGb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information. - Allowed values: 
- AutotunePolicies []InstanceConfiguration Instance Details Block Volume Create Details Autotune Policy 
- The list of autotune policies enabled for this volume.
- AvailabilityDomain string
- The availability domain of the volume. Example: Uocm:PHX-AD-1
- BackupPolicy stringId 
- If provided, specifies the ID of the volume backup policy to assign to the newly created volume. If omitted, no policy will be assigned.
- BlockVolume InstanceReplicas Configuration Instance Details Block Volume Create Details Block Volume Replicas 
- The list of block volume replicas to be enabled for this volume in the specified destination availability domains.
- ClusterPlacement stringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- CompartmentId string
- The OCID of the compartment that contains the volume.
- map[string]interface{}
- Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- map[string]interface{}
- Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- IsAuto boolTune Enabled 
- Specifies whether the auto-tune performance is enabled for this boot volume. This field is deprecated. Use the InstanceConfigurationDetachedVolumeAutotunePolicyinstead to enable the volume for detached autotune.
- KmsKey stringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- SizeIn stringGbs 
- The size of the volume in GBs.
- SourceDetails InstanceConfiguration Instance Details Block Volume Create Details Source Details 
- VpusPer stringGb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information. - Allowed values: 
- autotunePolicies List<InstanceConfiguration Instance Details Block Volume Create Details Autotune Policy> 
- The list of autotune policies enabled for this volume.
- availabilityDomain String
- The availability domain of the volume. Example: Uocm:PHX-AD-1
- backupPolicy StringId 
- If provided, specifies the ID of the volume backup policy to assign to the newly created volume. If omitted, no policy will be assigned.
- blockVolume InstanceReplicas Configuration Instance Details Block Volume Create Details Block Volume Replicas 
- The list of block volume replicas to be enabled for this volume in the specified destination availability domains.
- clusterPlacement StringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartmentId String
- The OCID of the compartment that contains the volume.
- Map<String,Object>
- Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<String,Object>
- Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- isAuto BooleanTune Enabled 
- Specifies whether the auto-tune performance is enabled for this boot volume. This field is deprecated. Use the InstanceConfigurationDetachedVolumeAutotunePolicyinstead to enable the volume for detached autotune.
- kmsKey StringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- sizeIn StringGbs 
- The size of the volume in GBs.
- sourceDetails InstanceConfiguration Instance Details Block Volume Create Details Source Details 
- vpusPer StringGb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information. - Allowed values: 
- autotunePolicies InstanceConfiguration Instance Details Block Volume Create Details Autotune Policy[] 
- The list of autotune policies enabled for this volume.
- availabilityDomain string
- The availability domain of the volume. Example: Uocm:PHX-AD-1
- backupPolicy stringId 
- If provided, specifies the ID of the volume backup policy to assign to the newly created volume. If omitted, no policy will be assigned.
- blockVolume InstanceReplicas Configuration Instance Details Block Volume Create Details Block Volume Replicas 
- The list of block volume replicas to be enabled for this volume in the specified destination availability domains.
- clusterPlacement stringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartmentId string
- The OCID of the compartment that contains the volume.
- {[key: string]: any}
- Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName string
- A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- {[key: string]: any}
- Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- isAuto booleanTune Enabled 
- Specifies whether the auto-tune performance is enabled for this boot volume. This field is deprecated. Use the InstanceConfigurationDetachedVolumeAutotunePolicyinstead to enable the volume for detached autotune.
- kmsKey stringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- sizeIn stringGbs 
- The size of the volume in GBs.
- sourceDetails InstanceConfiguration Instance Details Block Volume Create Details Source Details 
- vpusPer stringGb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information. - Allowed values: 
- autotune_policies Sequence[core.Instance Configuration Instance Details Block Volume Create Details Autotune Policy] 
- The list of autotune policies enabled for this volume.
- availability_domain str
- The availability domain of the volume. Example: Uocm:PHX-AD-1
- backup_policy_ strid 
- If provided, specifies the ID of the volume backup policy to assign to the newly created volume. If omitted, no policy will be assigned.
- block_volume_ core.replicas Instance Configuration Instance Details Block Volume Create Details Block Volume Replicas 
- The list of block volume replicas to be enabled for this volume in the specified destination availability domains.
- cluster_placement_ strgroup_ id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartment_id str
- The OCID of the compartment that contains the volume.
- Mapping[str, Any]
- Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- display_name str
- A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Mapping[str, Any]
- Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- is_auto_ booltune_ enabled 
- Specifies whether the auto-tune performance is enabled for this boot volume. This field is deprecated. Use the InstanceConfigurationDetachedVolumeAutotunePolicyinstead to enable the volume for detached autotune.
- kms_key_ strid 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- size_in_ strgbs 
- The size of the volume in GBs.
- source_details core.Instance Configuration Instance Details Block Volume Create Details Source Details 
- vpus_per_ strgb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information. - Allowed values: 
- autotunePolicies List<Property Map>
- The list of autotune policies enabled for this volume.
- availabilityDomain String
- The availability domain of the volume. Example: Uocm:PHX-AD-1
- backupPolicy StringId 
- If provided, specifies the ID of the volume backup policy to assign to the newly created volume. If omitted, no policy will be assigned.
- blockVolume Property MapReplicas 
- The list of block volume replicas to be enabled for this volume in the specified destination availability domains.
- clusterPlacement StringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartmentId String
- The OCID of the compartment that contains the volume.
- Map<Any>
- Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<Any>
- Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- isAuto BooleanTune Enabled 
- Specifies whether the auto-tune performance is enabled for this boot volume. This field is deprecated. Use the InstanceConfigurationDetachedVolumeAutotunePolicyinstead to enable the volume for detached autotune.
- kmsKey StringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- sizeIn StringGbs 
- The size of the volume in GBs.
- sourceDetails Property Map
- vpusPer StringGb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information. - Allowed values: 
InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsAutotunePolicy, InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsAutotunePolicyArgs                    
- AutotuneType string
- This specifies the type of autotunes supported by OCI.
- MaxVpus stringPer Gb 
- This will be the maximum VPUs/GB performance level that the volume will be auto-tuned temporarily based on performance monitoring.
- AutotuneType string
- This specifies the type of autotunes supported by OCI.
- MaxVpus stringPer Gb 
- This will be the maximum VPUs/GB performance level that the volume will be auto-tuned temporarily based on performance monitoring.
- autotuneType String
- This specifies the type of autotunes supported by OCI.
- maxVpus StringPer Gb 
- This will be the maximum VPUs/GB performance level that the volume will be auto-tuned temporarily based on performance monitoring.
- autotuneType string
- This specifies the type of autotunes supported by OCI.
- maxVpus stringPer Gb 
- This will be the maximum VPUs/GB performance level that the volume will be auto-tuned temporarily based on performance monitoring.
- autotune_type str
- This specifies the type of autotunes supported by OCI.
- max_vpus_ strper_ gb 
- This will be the maximum VPUs/GB performance level that the volume will be auto-tuned temporarily based on performance monitoring.
- autotuneType String
- This specifies the type of autotunes supported by OCI.
- maxVpus StringPer Gb 
- This will be the maximum VPUs/GB performance level that the volume will be auto-tuned temporarily based on performance monitoring.
InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsBlockVolumeReplicas, InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsBlockVolumeReplicasArgs                      
- AvailabilityDomain string
- The availability domain of the block volume replica. Example: Uocm:PHX-AD-1
- DisplayName string
- The display name of the block volume replica. You may optionally specify a display name for the block volume replica, otherwise a default is provided.
- AvailabilityDomain string
- The availability domain of the block volume replica. Example: Uocm:PHX-AD-1
- DisplayName string
- The display name of the block volume replica. You may optionally specify a display name for the block volume replica, otherwise a default is provided.
- availabilityDomain String
- The availability domain of the block volume replica. Example: Uocm:PHX-AD-1
- displayName String
- The display name of the block volume replica. You may optionally specify a display name for the block volume replica, otherwise a default is provided.
- availabilityDomain string
- The availability domain of the block volume replica. Example: Uocm:PHX-AD-1
- displayName string
- The display name of the block volume replica. You may optionally specify a display name for the block volume replica, otherwise a default is provided.
- availability_domain str
- The availability domain of the block volume replica. Example: Uocm:PHX-AD-1
- display_name str
- The display name of the block volume replica. You may optionally specify a display name for the block volume replica, otherwise a default is provided.
- availabilityDomain String
- The availability domain of the block volume replica. Example: Uocm:PHX-AD-1
- displayName String
- The display name of the block volume replica. You may optionally specify a display name for the block volume replica, otherwise a default is provided.
InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsSourceDetails, InstanceConfigurationInstanceDetailsBlockVolumeCreateDetailsSourceDetailsArgs                    
InstanceConfigurationInstanceDetailsLaunchDetails, InstanceConfigurationInstanceDetailsLaunchDetailsArgs            
- AgentConfig InstanceConfiguration Instance Details Launch Details Agent Config 
- Configuration options for the Oracle Cloud Agent software running on the instance.
- AvailabilityConfig InstanceConfiguration Instance Details Launch Details Availability Config 
- Options for defining the availabiity of a VM instance after a maintenance event that impacts the underlying hardware.
- AvailabilityDomain string
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- CapacityReservation stringId 
- The OCID of the compute capacity reservation this instance is launched under.
- ClusterPlacement stringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- CompartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- CreateVnic InstanceDetails Configuration Instance Details Launch Details Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- DedicatedVm stringHost Id 
- The OCID of the dedicated virtual machine host to place the instance on.
- Dictionary<string, object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- ExtendedMetadata Dictionary<string, object>
- Additional metadata key/value pairs that you provide. They serve the same purpose and functionality as fields in the metadataobject.
- FaultDomain string
- A fault domain is a grouping of hardware and infrastructure within an availability domain. Each availability domain contains three fault domains. Fault domains let you distribute your instances so that they are not on the same physical hardware within a single availability domain. A hardware failure or Compute hardware maintenance that affects one fault domain does not affect instances in other fault domains.
- Dictionary<string, object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- InstanceOptions InstanceConfiguration Instance Details Launch Details Instance Options 
- Optional mutable instance options. As a part of Instance Metadata Service Security Header, This allows user to disable the legacy imds endpoints.
- IpxeScript string
- This is an advanced option.
- IsPv boolEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- LaunchMode string
- Specifies the configuration mode for launching virtual machine (VM) instances. The configuration modes are:- NATIVE- VM instances launch with iSCSI boot and VFIO devices. The default value for platform images.
- EMULATED- VM instances launch with emulated devices, such as the E1000 network driver and emulated SCSI disk controller.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
- CUSTOM- VM instances launch with custom configuration settings specified in the- LaunchOptionsparameter.
 
- LaunchOptions InstanceConfiguration Instance Details Launch Details Launch Options 
- Options for tuning the compatibility and performance of VM shapes. The values that you specify override any default values.
- Metadata Dictionary<string, object>
- Custom metadata key/value pairs that you provide, such as the SSH public key required to connect to the instance.
- PlatformConfig InstanceConfiguration Instance Details Launch Details Platform Config 
- The platform configuration requested for the instance.
- PreemptibleInstance InstanceConfig Configuration Instance Details Launch Details Preemptible Instance Config 
- Configuration options for preemptible instances.
- PreferredMaintenance stringAction 
- The preferred maintenance action for an instance. The default is LIVE_MIGRATE, if live migration is supported.- LIVE_MIGRATE- Run maintenance using a live migration.
- REBOOT- Run maintenance using a reboot.
 
- Shape string
- The shape of an instance. The shape determines the number of CPUs, amount of memory, and other resources allocated to the instance.
- ShapeConfig InstanceConfiguration Instance Details Launch Details Shape Config 
- The shape configuration requested for the instance.
- SourceDetails InstanceConfiguration Instance Details Launch Details Source Details 
- AgentConfig InstanceConfiguration Instance Details Launch Details Agent Config 
- Configuration options for the Oracle Cloud Agent software running on the instance.
- AvailabilityConfig InstanceConfiguration Instance Details Launch Details Availability Config 
- Options for defining the availabiity of a VM instance after a maintenance event that impacts the underlying hardware.
- AvailabilityDomain string
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- CapacityReservation stringId 
- The OCID of the compute capacity reservation this instance is launched under.
- ClusterPlacement stringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- CompartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- CreateVnic InstanceDetails Configuration Instance Details Launch Details Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- DedicatedVm stringHost Id 
- The OCID of the dedicated virtual machine host to place the instance on.
- map[string]interface{}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- ExtendedMetadata map[string]interface{}
- Additional metadata key/value pairs that you provide. They serve the same purpose and functionality as fields in the metadataobject.
- FaultDomain string
- A fault domain is a grouping of hardware and infrastructure within an availability domain. Each availability domain contains three fault domains. Fault domains let you distribute your instances so that they are not on the same physical hardware within a single availability domain. A hardware failure or Compute hardware maintenance that affects one fault domain does not affect instances in other fault domains.
- map[string]interface{}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- InstanceOptions InstanceConfiguration Instance Details Launch Details Instance Options 
- Optional mutable instance options. As a part of Instance Metadata Service Security Header, This allows user to disable the legacy imds endpoints.
- IpxeScript string
- This is an advanced option.
- IsPv boolEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- LaunchMode string
- Specifies the configuration mode for launching virtual machine (VM) instances. The configuration modes are:- NATIVE- VM instances launch with iSCSI boot and VFIO devices. The default value for platform images.
- EMULATED- VM instances launch with emulated devices, such as the E1000 network driver and emulated SCSI disk controller.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
- CUSTOM- VM instances launch with custom configuration settings specified in the- LaunchOptionsparameter.
 
- LaunchOptions InstanceConfiguration Instance Details Launch Details Launch Options 
- Options for tuning the compatibility and performance of VM shapes. The values that you specify override any default values.
- Metadata map[string]interface{}
- Custom metadata key/value pairs that you provide, such as the SSH public key required to connect to the instance.
- PlatformConfig InstanceConfiguration Instance Details Launch Details Platform Config 
- The platform configuration requested for the instance.
- PreemptibleInstance InstanceConfig Configuration Instance Details Launch Details Preemptible Instance Config 
- Configuration options for preemptible instances.
- PreferredMaintenance stringAction 
- The preferred maintenance action for an instance. The default is LIVE_MIGRATE, if live migration is supported.- LIVE_MIGRATE- Run maintenance using a live migration.
- REBOOT- Run maintenance using a reboot.
 
- Shape string
- The shape of an instance. The shape determines the number of CPUs, amount of memory, and other resources allocated to the instance.
- ShapeConfig InstanceConfiguration Instance Details Launch Details Shape Config 
- The shape configuration requested for the instance.
- SourceDetails InstanceConfiguration Instance Details Launch Details Source Details 
- agentConfig InstanceConfiguration Instance Details Launch Details Agent Config 
- Configuration options for the Oracle Cloud Agent software running on the instance.
- availabilityConfig InstanceConfiguration Instance Details Launch Details Availability Config 
- Options for defining the availabiity of a VM instance after a maintenance event that impacts the underlying hardware.
- availabilityDomain String
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- capacityReservation StringId 
- The OCID of the compute capacity reservation this instance is launched under.
- clusterPlacement StringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartmentId String
- (Updatable) The OCID of the compartment containing the instance configuration.
- createVnic InstanceDetails Configuration Instance Details Launch Details Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- dedicatedVm StringHost Id 
- The OCID of the dedicated virtual machine host to place the instance on.
- Map<String,Object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- extendedMetadata Map<String,Object>
- Additional metadata key/value pairs that you provide. They serve the same purpose and functionality as fields in the metadataobject.
- faultDomain String
- A fault domain is a grouping of hardware and infrastructure within an availability domain. Each availability domain contains three fault domains. Fault domains let you distribute your instances so that they are not on the same physical hardware within a single availability domain. A hardware failure or Compute hardware maintenance that affects one fault domain does not affect instances in other fault domains.
- Map<String,Object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instanceOptions InstanceConfiguration Instance Details Launch Details Instance Options 
- Optional mutable instance options. As a part of Instance Metadata Service Security Header, This allows user to disable the legacy imds endpoints.
- ipxeScript String
- This is an advanced option.
- isPv BooleanEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- launchMode String
- Specifies the configuration mode for launching virtual machine (VM) instances. The configuration modes are:- NATIVE- VM instances launch with iSCSI boot and VFIO devices. The default value for platform images.
- EMULATED- VM instances launch with emulated devices, such as the E1000 network driver and emulated SCSI disk controller.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
- CUSTOM- VM instances launch with custom configuration settings specified in the- LaunchOptionsparameter.
 
- launchOptions InstanceConfiguration Instance Details Launch Details Launch Options 
- Options for tuning the compatibility and performance of VM shapes. The values that you specify override any default values.
- metadata Map<String,Object>
- Custom metadata key/value pairs that you provide, such as the SSH public key required to connect to the instance.
- platformConfig InstanceConfiguration Instance Details Launch Details Platform Config 
- The platform configuration requested for the instance.
- preemptibleInstance InstanceConfig Configuration Instance Details Launch Details Preemptible Instance Config 
- Configuration options for preemptible instances.
- preferredMaintenance StringAction 
- The preferred maintenance action for an instance. The default is LIVE_MIGRATE, if live migration is supported.- LIVE_MIGRATE- Run maintenance using a live migration.
- REBOOT- Run maintenance using a reboot.
 
- shape String
- The shape of an instance. The shape determines the number of CPUs, amount of memory, and other resources allocated to the instance.
- shapeConfig InstanceConfiguration Instance Details Launch Details Shape Config 
- The shape configuration requested for the instance.
- sourceDetails InstanceConfiguration Instance Details Launch Details Source Details 
- agentConfig InstanceConfiguration Instance Details Launch Details Agent Config 
- Configuration options for the Oracle Cloud Agent software running on the instance.
- availabilityConfig InstanceConfiguration Instance Details Launch Details Availability Config 
- Options for defining the availabiity of a VM instance after a maintenance event that impacts the underlying hardware.
- availabilityDomain string
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- capacityReservation stringId 
- The OCID of the compute capacity reservation this instance is launched under.
- clusterPlacement stringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- createVnic InstanceDetails Configuration Instance Details Launch Details Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- dedicatedVm stringHost Id 
- The OCID of the dedicated virtual machine host to place the instance on.
- {[key: string]: any}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- extendedMetadata {[key: string]: any}
- Additional metadata key/value pairs that you provide. They serve the same purpose and functionality as fields in the metadataobject.
- faultDomain string
- A fault domain is a grouping of hardware and infrastructure within an availability domain. Each availability domain contains three fault domains. Fault domains let you distribute your instances so that they are not on the same physical hardware within a single availability domain. A hardware failure or Compute hardware maintenance that affects one fault domain does not affect instances in other fault domains.
- {[key: string]: any}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instanceOptions InstanceConfiguration Instance Details Launch Details Instance Options 
- Optional mutable instance options. As a part of Instance Metadata Service Security Header, This allows user to disable the legacy imds endpoints.
- ipxeScript string
- This is an advanced option.
- isPv booleanEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- launchMode string
- Specifies the configuration mode for launching virtual machine (VM) instances. The configuration modes are:- NATIVE- VM instances launch with iSCSI boot and VFIO devices. The default value for platform images.
- EMULATED- VM instances launch with emulated devices, such as the E1000 network driver and emulated SCSI disk controller.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
- CUSTOM- VM instances launch with custom configuration settings specified in the- LaunchOptionsparameter.
 
- launchOptions InstanceConfiguration Instance Details Launch Details Launch Options 
- Options for tuning the compatibility and performance of VM shapes. The values that you specify override any default values.
- metadata {[key: string]: any}
- Custom metadata key/value pairs that you provide, such as the SSH public key required to connect to the instance.
- platformConfig InstanceConfiguration Instance Details Launch Details Platform Config 
- The platform configuration requested for the instance.
- preemptibleInstance InstanceConfig Configuration Instance Details Launch Details Preemptible Instance Config 
- Configuration options for preemptible instances.
- preferredMaintenance stringAction 
- The preferred maintenance action for an instance. The default is LIVE_MIGRATE, if live migration is supported.- LIVE_MIGRATE- Run maintenance using a live migration.
- REBOOT- Run maintenance using a reboot.
 
- shape string
- The shape of an instance. The shape determines the number of CPUs, amount of memory, and other resources allocated to the instance.
- shapeConfig InstanceConfiguration Instance Details Launch Details Shape Config 
- The shape configuration requested for the instance.
- sourceDetails InstanceConfiguration Instance Details Launch Details Source Details 
- agent_config core.Instance Configuration Instance Details Launch Details Agent Config 
- Configuration options for the Oracle Cloud Agent software running on the instance.
- availability_config core.Instance Configuration Instance Details Launch Details Availability Config 
- Options for defining the availabiity of a VM instance after a maintenance event that impacts the underlying hardware.
- availability_domain str
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- capacity_reservation_ strid 
- The OCID of the compute capacity reservation this instance is launched under.
- cluster_placement_ strgroup_ id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartment_id str
- (Updatable) The OCID of the compartment containing the instance configuration.
- create_vnic_ core.details Instance Configuration Instance Details Launch Details Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- dedicated_vm_ strhost_ id 
- The OCID of the dedicated virtual machine host to place the instance on.
- Mapping[str, Any]
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- display_name str
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- extended_metadata Mapping[str, Any]
- Additional metadata key/value pairs that you provide. They serve the same purpose and functionality as fields in the metadataobject.
- fault_domain str
- A fault domain is a grouping of hardware and infrastructure within an availability domain. Each availability domain contains three fault domains. Fault domains let you distribute your instances so that they are not on the same physical hardware within a single availability domain. A hardware failure or Compute hardware maintenance that affects one fault domain does not affect instances in other fault domains.
- Mapping[str, Any]
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instance_options core.Instance Configuration Instance Details Launch Details Instance Options 
- Optional mutable instance options. As a part of Instance Metadata Service Security Header, This allows user to disable the legacy imds endpoints.
- ipxe_script str
- This is an advanced option.
- is_pv_ boolencryption_ in_ transit_ enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- launch_mode str
- Specifies the configuration mode for launching virtual machine (VM) instances. The configuration modes are:- NATIVE- VM instances launch with iSCSI boot and VFIO devices. The default value for platform images.
- EMULATED- VM instances launch with emulated devices, such as the E1000 network driver and emulated SCSI disk controller.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
- CUSTOM- VM instances launch with custom configuration settings specified in the- LaunchOptionsparameter.
 
- launch_options core.Instance Configuration Instance Details Launch Details Launch Options 
- Options for tuning the compatibility and performance of VM shapes. The values that you specify override any default values.
- metadata Mapping[str, Any]
- Custom metadata key/value pairs that you provide, such as the SSH public key required to connect to the instance.
- platform_config core.Instance Configuration Instance Details Launch Details Platform Config 
- The platform configuration requested for the instance.
- preemptible_instance_ core.config Instance Configuration Instance Details Launch Details Preemptible Instance Config 
- Configuration options for preemptible instances.
- preferred_maintenance_ straction 
- The preferred maintenance action for an instance. The default is LIVE_MIGRATE, if live migration is supported.- LIVE_MIGRATE- Run maintenance using a live migration.
- REBOOT- Run maintenance using a reboot.
 
- shape str
- The shape of an instance. The shape determines the number of CPUs, amount of memory, and other resources allocated to the instance.
- shape_config core.Instance Configuration Instance Details Launch Details Shape Config 
- The shape configuration requested for the instance.
- source_details core.Instance Configuration Instance Details Launch Details Source Details 
- agentConfig Property Map
- Configuration options for the Oracle Cloud Agent software running on the instance.
- availabilityConfig Property Map
- Options for defining the availabiity of a VM instance after a maintenance event that impacts the underlying hardware.
- availabilityDomain String
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- capacityReservation StringId 
- The OCID of the compute capacity reservation this instance is launched under.
- clusterPlacement StringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartmentId String
- (Updatable) The OCID of the compartment containing the instance configuration.
- createVnic Property MapDetails 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- dedicatedVm StringHost Id 
- The OCID of the dedicated virtual machine host to place the instance on.
- Map<Any>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- extendedMetadata Map<Any>
- Additional metadata key/value pairs that you provide. They serve the same purpose and functionality as fields in the metadataobject.
- faultDomain String
- A fault domain is a grouping of hardware and infrastructure within an availability domain. Each availability domain contains three fault domains. Fault domains let you distribute your instances so that they are not on the same physical hardware within a single availability domain. A hardware failure or Compute hardware maintenance that affects one fault domain does not affect instances in other fault domains.
- Map<Any>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instanceOptions Property Map
- Optional mutable instance options. As a part of Instance Metadata Service Security Header, This allows user to disable the legacy imds endpoints.
- ipxeScript String
- This is an advanced option.
- isPv BooleanEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- launchMode String
- Specifies the configuration mode for launching virtual machine (VM) instances. The configuration modes are:- NATIVE- VM instances launch with iSCSI boot and VFIO devices. The default value for platform images.
- EMULATED- VM instances launch with emulated devices, such as the E1000 network driver and emulated SCSI disk controller.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
- CUSTOM- VM instances launch with custom configuration settings specified in the- LaunchOptionsparameter.
 
- launchOptions Property Map
- Options for tuning the compatibility and performance of VM shapes. The values that you specify override any default values.
- metadata Map<Any>
- Custom metadata key/value pairs that you provide, such as the SSH public key required to connect to the instance.
- platformConfig Property Map
- The platform configuration requested for the instance.
- preemptibleInstance Property MapConfig 
- Configuration options for preemptible instances.
- preferredMaintenance StringAction 
- The preferred maintenance action for an instance. The default is LIVE_MIGRATE, if live migration is supported.- LIVE_MIGRATE- Run maintenance using a live migration.
- REBOOT- Run maintenance using a reboot.
 
- shape String
- The shape of an instance. The shape determines the number of CPUs, amount of memory, and other resources allocated to the instance.
- shapeConfig Property Map
- The shape configuration requested for the instance.
- sourceDetails Property Map
InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfig, InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigArgs                
- AreAll boolPlugins Disabled 
- Whether Oracle Cloud Agent can run all the available plugins. This includes the management and monitoring plugins. - To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent. 
- IsManagement boolDisabled 
- Whether Oracle Cloud Agent can run all the available management plugins. Default value is false (management plugins are enabled). - These are the management plugins: OS Management Service Agent and Compute Instance Run Command. - The management plugins are controlled by this parameter and by the per-plugin configuration in the - pluginsConfigobject.- If isManagementDisabledis true, all of the management plugins are disabled, regardless of the per-plugin configuration.
- If isManagementDisabledis false, all of the management plugins are enabled. You can optionally disable individual management plugins by providing a value in thepluginsConfigobject.
 
- If 
- IsMonitoring boolDisabled 
- Whether Oracle Cloud Agent can gather performance metrics and monitor the instance using the monitoring plugins. Default value is false (monitoring plugins are enabled). - These are the monitoring plugins: Compute Instance Monitoring and Custom Logs Monitoring. - The monitoring plugins are controlled by this parameter and by the per-plugin configuration in the - pluginsConfigobject.- If isMonitoringDisabledis true, all of the monitoring plugins are disabled, regardless of the per-plugin configuration.
- If isMonitoringDisabledis false, all of the monitoring plugins are enabled. You can optionally disable individual monitoring plugins by providing a value in thepluginsConfigobject.
 
- If 
- PluginsConfigs List<InstanceConfiguration Instance Details Launch Details Agent Config Plugins Config> 
- The configuration of plugins associated with this instance.
- AreAll boolPlugins Disabled 
- Whether Oracle Cloud Agent can run all the available plugins. This includes the management and monitoring plugins. - To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent. 
- IsManagement boolDisabled 
- Whether Oracle Cloud Agent can run all the available management plugins. Default value is false (management plugins are enabled). - These are the management plugins: OS Management Service Agent and Compute Instance Run Command. - The management plugins are controlled by this parameter and by the per-plugin configuration in the - pluginsConfigobject.- If isManagementDisabledis true, all of the management plugins are disabled, regardless of the per-plugin configuration.
- If isManagementDisabledis false, all of the management plugins are enabled. You can optionally disable individual management plugins by providing a value in thepluginsConfigobject.
 
- If 
- IsMonitoring boolDisabled 
- Whether Oracle Cloud Agent can gather performance metrics and monitor the instance using the monitoring plugins. Default value is false (monitoring plugins are enabled). - These are the monitoring plugins: Compute Instance Monitoring and Custom Logs Monitoring. - The monitoring plugins are controlled by this parameter and by the per-plugin configuration in the - pluginsConfigobject.- If isMonitoringDisabledis true, all of the monitoring plugins are disabled, regardless of the per-plugin configuration.
- If isMonitoringDisabledis false, all of the monitoring plugins are enabled. You can optionally disable individual monitoring plugins by providing a value in thepluginsConfigobject.
 
- If 
- PluginsConfigs []InstanceConfiguration Instance Details Launch Details Agent Config Plugins Config 
- The configuration of plugins associated with this instance.
- areAll BooleanPlugins Disabled 
- Whether Oracle Cloud Agent can run all the available plugins. This includes the management and monitoring plugins. - To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent. 
- isManagement BooleanDisabled 
- Whether Oracle Cloud Agent can run all the available management plugins. Default value is false (management plugins are enabled). - These are the management plugins: OS Management Service Agent and Compute Instance Run Command. - The management plugins are controlled by this parameter and by the per-plugin configuration in the - pluginsConfigobject.- If isManagementDisabledis true, all of the management plugins are disabled, regardless of the per-plugin configuration.
- If isManagementDisabledis false, all of the management plugins are enabled. You can optionally disable individual management plugins by providing a value in thepluginsConfigobject.
 
- If 
- isMonitoring BooleanDisabled 
- Whether Oracle Cloud Agent can gather performance metrics and monitor the instance using the monitoring plugins. Default value is false (monitoring plugins are enabled). - These are the monitoring plugins: Compute Instance Monitoring and Custom Logs Monitoring. - The monitoring plugins are controlled by this parameter and by the per-plugin configuration in the - pluginsConfigobject.- If isMonitoringDisabledis true, all of the monitoring plugins are disabled, regardless of the per-plugin configuration.
- If isMonitoringDisabledis false, all of the monitoring plugins are enabled. You can optionally disable individual monitoring plugins by providing a value in thepluginsConfigobject.
 
- If 
- pluginsConfigs List<InstanceConfiguration Instance Details Launch Details Agent Config Plugins Config> 
- The configuration of plugins associated with this instance.
- areAll booleanPlugins Disabled 
- Whether Oracle Cloud Agent can run all the available plugins. This includes the management and monitoring plugins. - To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent. 
- isManagement booleanDisabled 
- Whether Oracle Cloud Agent can run all the available management plugins. Default value is false (management plugins are enabled). - These are the management plugins: OS Management Service Agent and Compute Instance Run Command. - The management plugins are controlled by this parameter and by the per-plugin configuration in the - pluginsConfigobject.- If isManagementDisabledis true, all of the management plugins are disabled, regardless of the per-plugin configuration.
- If isManagementDisabledis false, all of the management plugins are enabled. You can optionally disable individual management plugins by providing a value in thepluginsConfigobject.
 
- If 
- isMonitoring booleanDisabled 
- Whether Oracle Cloud Agent can gather performance metrics and monitor the instance using the monitoring plugins. Default value is false (monitoring plugins are enabled). - These are the monitoring plugins: Compute Instance Monitoring and Custom Logs Monitoring. - The monitoring plugins are controlled by this parameter and by the per-plugin configuration in the - pluginsConfigobject.- If isMonitoringDisabledis true, all of the monitoring plugins are disabled, regardless of the per-plugin configuration.
- If isMonitoringDisabledis false, all of the monitoring plugins are enabled. You can optionally disable individual monitoring plugins by providing a value in thepluginsConfigobject.
 
- If 
- pluginsConfigs InstanceConfiguration Instance Details Launch Details Agent Config Plugins Config[] 
- The configuration of plugins associated with this instance.
- are_all_ boolplugins_ disabled 
- Whether Oracle Cloud Agent can run all the available plugins. This includes the management and monitoring plugins. - To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent. 
- is_management_ booldisabled 
- Whether Oracle Cloud Agent can run all the available management plugins. Default value is false (management plugins are enabled). - These are the management plugins: OS Management Service Agent and Compute Instance Run Command. - The management plugins are controlled by this parameter and by the per-plugin configuration in the - pluginsConfigobject.- If isManagementDisabledis true, all of the management plugins are disabled, regardless of the per-plugin configuration.
- If isManagementDisabledis false, all of the management plugins are enabled. You can optionally disable individual management plugins by providing a value in thepluginsConfigobject.
 
- If 
- is_monitoring_ booldisabled 
- Whether Oracle Cloud Agent can gather performance metrics and monitor the instance using the monitoring plugins. Default value is false (monitoring plugins are enabled). - These are the monitoring plugins: Compute Instance Monitoring and Custom Logs Monitoring. - The monitoring plugins are controlled by this parameter and by the per-plugin configuration in the - pluginsConfigobject.- If isMonitoringDisabledis true, all of the monitoring plugins are disabled, regardless of the per-plugin configuration.
- If isMonitoringDisabledis false, all of the monitoring plugins are enabled. You can optionally disable individual monitoring plugins by providing a value in thepluginsConfigobject.
 
- If 
- plugins_configs Sequence[core.Instance Configuration Instance Details Launch Details Agent Config Plugins Config] 
- The configuration of plugins associated with this instance.
- areAll BooleanPlugins Disabled 
- Whether Oracle Cloud Agent can run all the available plugins. This includes the management and monitoring plugins. - To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent. 
- isManagement BooleanDisabled 
- Whether Oracle Cloud Agent can run all the available management plugins. Default value is false (management plugins are enabled). - These are the management plugins: OS Management Service Agent and Compute Instance Run Command. - The management plugins are controlled by this parameter and by the per-plugin configuration in the - pluginsConfigobject.- If isManagementDisabledis true, all of the management plugins are disabled, regardless of the per-plugin configuration.
- If isManagementDisabledis false, all of the management plugins are enabled. You can optionally disable individual management plugins by providing a value in thepluginsConfigobject.
 
- If 
- isMonitoring BooleanDisabled 
- Whether Oracle Cloud Agent can gather performance metrics and monitor the instance using the monitoring plugins. Default value is false (monitoring plugins are enabled). - These are the monitoring plugins: Compute Instance Monitoring and Custom Logs Monitoring. - The monitoring plugins are controlled by this parameter and by the per-plugin configuration in the - pluginsConfigobject.- If isMonitoringDisabledis true, all of the monitoring plugins are disabled, regardless of the per-plugin configuration.
- If isMonitoringDisabledis false, all of the monitoring plugins are enabled. You can optionally disable individual monitoring plugins by providing a value in thepluginsConfigobject.
 
- If 
- pluginsConfigs List<Property Map>
- The configuration of plugins associated with this instance.
InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfig, InstanceConfigurationInstanceDetailsLaunchDetailsAgentConfigPluginsConfigArgs                    
- DesiredState string
- Whether the plugin should be enabled or disabled.
To enable the monitoring and management plugins, the isMonitoringDisabledandisManagementDisabledattributes must also be set to false.
- Name string
- The plugin name. To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent.
- DesiredState string
- Whether the plugin should be enabled or disabled.
To enable the monitoring and management plugins, the isMonitoringDisabledandisManagementDisabledattributes must also be set to false.
- Name string
- The plugin name. To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent.
- desiredState String
- Whether the plugin should be enabled or disabled.
To enable the monitoring and management plugins, the isMonitoringDisabledandisManagementDisabledattributes must also be set to false.
- name String
- The plugin name. To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent.
- desiredState string
- Whether the plugin should be enabled or disabled.
To enable the monitoring and management plugins, the isMonitoringDisabledandisManagementDisabledattributes must also be set to false.
- name string
- The plugin name. To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent.
- desired_state str
- Whether the plugin should be enabled or disabled.
To enable the monitoring and management plugins, the isMonitoringDisabledandisManagementDisabledattributes must also be set to false.
- name str
- The plugin name. To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent.
- desiredState String
- Whether the plugin should be enabled or disabled.
To enable the monitoring and management plugins, the isMonitoringDisabledandisManagementDisabledattributes must also be set to false.
- name String
- The plugin name. To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent.
InstanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfig, InstanceConfigurationInstanceDetailsLaunchDetailsAvailabilityConfigArgs                
- IsLive boolMigration Preferred 
- Whether to live migrate supported VM instances to a healthy physical VM host without disrupting running instances during infrastructure maintenance events. If null, Oracle chooses the best option for migrating the VM during infrastructure maintenance events.
- RecoveryAction string
- The lifecycle state for an instance when it is recovered after infrastructure maintenance.- RESTORE_INSTANCE- The instance is restored to the lifecycle state it was in before the maintenance event. If the instance was running, it is automatically rebooted. This is the default action when a value is not set.
- STOP_INSTANCE- The instance is recovered in the stopped state.
 
- IsLive boolMigration Preferred 
- Whether to live migrate supported VM instances to a healthy physical VM host without disrupting running instances during infrastructure maintenance events. If null, Oracle chooses the best option for migrating the VM during infrastructure maintenance events.
- RecoveryAction string
- The lifecycle state for an instance when it is recovered after infrastructure maintenance.- RESTORE_INSTANCE- The instance is restored to the lifecycle state it was in before the maintenance event. If the instance was running, it is automatically rebooted. This is the default action when a value is not set.
- STOP_INSTANCE- The instance is recovered in the stopped state.
 
- isLive BooleanMigration Preferred 
- Whether to live migrate supported VM instances to a healthy physical VM host without disrupting running instances during infrastructure maintenance events. If null, Oracle chooses the best option for migrating the VM during infrastructure maintenance events.
- recoveryAction String
- The lifecycle state for an instance when it is recovered after infrastructure maintenance.- RESTORE_INSTANCE- The instance is restored to the lifecycle state it was in before the maintenance event. If the instance was running, it is automatically rebooted. This is the default action when a value is not set.
- STOP_INSTANCE- The instance is recovered in the stopped state.
 
- isLive booleanMigration Preferred 
- Whether to live migrate supported VM instances to a healthy physical VM host without disrupting running instances during infrastructure maintenance events. If null, Oracle chooses the best option for migrating the VM during infrastructure maintenance events.
- recoveryAction string
- The lifecycle state for an instance when it is recovered after infrastructure maintenance.- RESTORE_INSTANCE- The instance is restored to the lifecycle state it was in before the maintenance event. If the instance was running, it is automatically rebooted. This is the default action when a value is not set.
- STOP_INSTANCE- The instance is recovered in the stopped state.
 
- is_live_ boolmigration_ preferred 
- Whether to live migrate supported VM instances to a healthy physical VM host without disrupting running instances during infrastructure maintenance events. If null, Oracle chooses the best option for migrating the VM during infrastructure maintenance events.
- recovery_action str
- The lifecycle state for an instance when it is recovered after infrastructure maintenance.- RESTORE_INSTANCE- The instance is restored to the lifecycle state it was in before the maintenance event. If the instance was running, it is automatically rebooted. This is the default action when a value is not set.
- STOP_INSTANCE- The instance is recovered in the stopped state.
 
- isLive BooleanMigration Preferred 
- Whether to live migrate supported VM instances to a healthy physical VM host without disrupting running instances during infrastructure maintenance events. If null, Oracle chooses the best option for migrating the VM during infrastructure maintenance events.
- recoveryAction String
- The lifecycle state for an instance when it is recovered after infrastructure maintenance.- RESTORE_INSTANCE- The instance is restored to the lifecycle state it was in before the maintenance event. If the instance was running, it is automatically rebooted. This is the default action when a value is not set.
- STOP_INSTANCE- The instance is recovered in the stopped state.
 
InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetails, InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsArgs                  
- AssignIpv6ip bool
- AssignPrivate boolDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- AssignPublic boolIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Dictionary<string, object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Dictionary<string, object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- HostnameLabel string
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- Ipv6addressIpv6subnet List<InstanceCidr Pair Details Configuration Instance Details Launch Details Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail> 
- NsgIds List<string>
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- PrivateIp string
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- SkipSource boolDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- SubnetId string
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- AssignIpv6ip bool
- AssignPrivate boolDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- AssignPublic boolIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- map[string]interface{}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- map[string]interface{}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- HostnameLabel string
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- Ipv6addressIpv6subnet []InstanceCidr Pair Details Configuration Instance Details Launch Details Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail 
- NsgIds []string
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- PrivateIp string
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- SkipSource boolDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- SubnetId string
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assignIpv6ip Boolean
- assignPrivate BooleanDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assignPublic BooleanIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Map<String,Object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<String,Object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostnameLabel String
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6addressIpv6subnet List<InstanceCidr Pair Details Configuration Instance Details Launch Details Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail> 
- nsgIds List<String>
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- privateIp String
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skipSource BooleanDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnetId String
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assignIpv6ip boolean
- assignPrivate booleanDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assignPublic booleanIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- {[key: string]: any}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- {[key: string]: any}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostnameLabel string
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6addressIpv6subnet InstanceCidr Pair Details Configuration Instance Details Launch Details Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail[] 
- nsgIds string[]
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- privateIp string
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skipSource booleanDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnetId string
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assign_ipv6ip bool
- assign_private_ booldns_ record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assign_public_ boolip 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Mapping[str, Any]
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- display_name str
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Mapping[str, Any]
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostname_label str
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6address_ipv6subnet_ Sequence[core.cidr_ pair_ details Instance Configuration Instance Details Launch Details Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail] 
- nsg_ids Sequence[str]
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- private_ip str
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skip_source_ booldest_ check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnet_id str
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assignIpv6ip Boolean
- assignPrivate BooleanDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assignPublic BooleanIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Map<Any>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<Any>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostnameLabel String
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6addressIpv6subnet List<Property Map>Cidr Pair Details 
- nsgIds List<String>
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- privateIp String
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skipSource BooleanDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnetId String
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetail, InstanceConfigurationInstanceDetailsLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs                            
- Ipv6address string
- Ipv6subnetCidr string
- Ipv6address string
- Ipv6subnetCidr string
- ipv6address String
- ipv6subnetCidr String
- ipv6address string
- ipv6subnetCidr string
- ipv6address str
- ipv6subnet_cidr str
- ipv6address String
- ipv6subnetCidr String
InstanceConfigurationInstanceDetailsLaunchDetailsInstanceOptions, InstanceConfigurationInstanceDetailsLaunchDetailsInstanceOptionsArgs                
- AreLegacy boolImds Endpoints Disabled 
- Whether to disable the legacy (/v1) instance metadata service endpoints. Customers who have migrated to /v2 should set this to true for added security. Default is false.
- AreLegacy boolImds Endpoints Disabled 
- Whether to disable the legacy (/v1) instance metadata service endpoints. Customers who have migrated to /v2 should set this to true for added security. Default is false.
- areLegacy BooleanImds Endpoints Disabled 
- Whether to disable the legacy (/v1) instance metadata service endpoints. Customers who have migrated to /v2 should set this to true for added security. Default is false.
- areLegacy booleanImds Endpoints Disabled 
- Whether to disable the legacy (/v1) instance metadata service endpoints. Customers who have migrated to /v2 should set this to true for added security. Default is false.
- are_legacy_ boolimds_ endpoints_ disabled 
- Whether to disable the legacy (/v1) instance metadata service endpoints. Customers who have migrated to /v2 should set this to true for added security. Default is false.
- areLegacy BooleanImds Endpoints Disabled 
- Whether to disable the legacy (/v1) instance metadata service endpoints. Customers who have migrated to /v2 should set this to true for added security. Default is false.
InstanceConfigurationInstanceDetailsLaunchDetailsLaunchOptions, InstanceConfigurationInstanceDetailsLaunchDetailsLaunchOptionsArgs                
- BootVolume stringType 
- Emulation type for the boot volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- Firmware string
- Firmware used to boot VM. Select the option that matches your operating system.- BIOS- Boot VM using BIOS style firmware. This is compatible with both 32 bit and 64 bit operating systems that boot using MBR style bootloaders.
- UEFI_64- Boot VM using UEFI style firmware compatible with 64 bit operating systems. This is the default for platform images.
 
- IsConsistent boolVolume Naming Enabled 
- Whether to enable consistent volume naming feature. Defaults to false.
- IsPv boolEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- NetworkType string
- Emulation type for the physical network interface card (NIC).- E1000- Emulated Gigabit ethernet controller. Compatible with Linux e1000 network driver.
- VFIO- Direct attached Virtual Function network controller. This is the networking type when you launch an instance using hardware-assisted (SR-IOV) networking.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
 
- RemoteData stringVolume Type 
- Emulation type for volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- BootVolume stringType 
- Emulation type for the boot volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- Firmware string
- Firmware used to boot VM. Select the option that matches your operating system.- BIOS- Boot VM using BIOS style firmware. This is compatible with both 32 bit and 64 bit operating systems that boot using MBR style bootloaders.
- UEFI_64- Boot VM using UEFI style firmware compatible with 64 bit operating systems. This is the default for platform images.
 
- IsConsistent boolVolume Naming Enabled 
- Whether to enable consistent volume naming feature. Defaults to false.
- IsPv boolEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- NetworkType string
- Emulation type for the physical network interface card (NIC).- E1000- Emulated Gigabit ethernet controller. Compatible with Linux e1000 network driver.
- VFIO- Direct attached Virtual Function network controller. This is the networking type when you launch an instance using hardware-assisted (SR-IOV) networking.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
 
- RemoteData stringVolume Type 
- Emulation type for volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- bootVolume StringType 
- Emulation type for the boot volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- firmware String
- Firmware used to boot VM. Select the option that matches your operating system.- BIOS- Boot VM using BIOS style firmware. This is compatible with both 32 bit and 64 bit operating systems that boot using MBR style bootloaders.
- UEFI_64- Boot VM using UEFI style firmware compatible with 64 bit operating systems. This is the default for platform images.
 
- isConsistent BooleanVolume Naming Enabled 
- Whether to enable consistent volume naming feature. Defaults to false.
- isPv BooleanEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- networkType String
- Emulation type for the physical network interface card (NIC).- E1000- Emulated Gigabit ethernet controller. Compatible with Linux e1000 network driver.
- VFIO- Direct attached Virtual Function network controller. This is the networking type when you launch an instance using hardware-assisted (SR-IOV) networking.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
 
- remoteData StringVolume Type 
- Emulation type for volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- bootVolume stringType 
- Emulation type for the boot volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- firmware string
- Firmware used to boot VM. Select the option that matches your operating system.- BIOS- Boot VM using BIOS style firmware. This is compatible with both 32 bit and 64 bit operating systems that boot using MBR style bootloaders.
- UEFI_64- Boot VM using UEFI style firmware compatible with 64 bit operating systems. This is the default for platform images.
 
- isConsistent booleanVolume Naming Enabled 
- Whether to enable consistent volume naming feature. Defaults to false.
- isPv booleanEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- networkType string
- Emulation type for the physical network interface card (NIC).- E1000- Emulated Gigabit ethernet controller. Compatible with Linux e1000 network driver.
- VFIO- Direct attached Virtual Function network controller. This is the networking type when you launch an instance using hardware-assisted (SR-IOV) networking.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
 
- remoteData stringVolume Type 
- Emulation type for volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- boot_volume_ strtype 
- Emulation type for the boot volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- firmware str
- Firmware used to boot VM. Select the option that matches your operating system.- BIOS- Boot VM using BIOS style firmware. This is compatible with both 32 bit and 64 bit operating systems that boot using MBR style bootloaders.
- UEFI_64- Boot VM using UEFI style firmware compatible with 64 bit operating systems. This is the default for platform images.
 
- is_consistent_ boolvolume_ naming_ enabled 
- Whether to enable consistent volume naming feature. Defaults to false.
- is_pv_ boolencryption_ in_ transit_ enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- network_type str
- Emulation type for the physical network interface card (NIC).- E1000- Emulated Gigabit ethernet controller. Compatible with Linux e1000 network driver.
- VFIO- Direct attached Virtual Function network controller. This is the networking type when you launch an instance using hardware-assisted (SR-IOV) networking.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
 
- remote_data_ strvolume_ type 
- Emulation type for volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- bootVolume StringType 
- Emulation type for the boot volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- firmware String
- Firmware used to boot VM. Select the option that matches your operating system.- BIOS- Boot VM using BIOS style firmware. This is compatible with both 32 bit and 64 bit operating systems that boot using MBR style bootloaders.
- UEFI_64- Boot VM using UEFI style firmware compatible with 64 bit operating systems. This is the default for platform images.
 
- isConsistent BooleanVolume Naming Enabled 
- Whether to enable consistent volume naming feature. Defaults to false.
- isPv BooleanEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- networkType String
- Emulation type for the physical network interface card (NIC).- E1000- Emulated Gigabit ethernet controller. Compatible with Linux e1000 network driver.
- VFIO- Direct attached Virtual Function network controller. This is the networking type when you launch an instance using hardware-assisted (SR-IOV) networking.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
 
- remoteData StringVolume Type 
- Emulation type for volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
InstanceConfigurationInstanceDetailsLaunchDetailsPlatformConfig, InstanceConfigurationInstanceDetailsLaunchDetailsPlatformConfigArgs                
- Type string
- The type of action to run when the instance is interrupted for eviction.
- AreVirtual boolInstructions Enabled 
- Whether virtualization instructions are available. For example, Secure Virtual Machine for AMD shapes or VT-x for Intel shapes.
- ConfigMap Dictionary<string, object>
- Instance Platform Configuration Configuration Map for flexible setting input.
- IsAccess boolControl Service Enabled 
- Whether the Access Control Service is enabled on the instance. When enabled, the platform can enforce PCIe device isolation, required for VFIO device pass-through.
- IsInput boolOutput Memory Management Unit Enabled 
- Whether the input-output memory management unit is enabled.
- IsMeasured boolBoot Enabled 
- Whether the Measured Boot feature is enabled on the instance.
- IsMemory boolEncryption Enabled 
- Whether the instance is a confidential instance. If this value is true, the instance is a confidential instance. The default value isfalse.
- IsSecure boolBoot Enabled 
- Whether Secure Boot is enabled on the instance.
- IsSymmetric boolMulti Threading Enabled 
- Whether symmetric multithreading is enabled on the instance. Symmetric multithreading is also called simultaneous multithreading (SMT) or Intel Hyper-Threading.
- IsTrusted boolPlatform Module Enabled 
- Whether the Trusted Platform Module (TPM) is enabled on the instance.
- NumaNodes stringPer Socket 
- The number of NUMA nodes per socket (NPS).
- PercentageOf intCores Enabled 
- The percentage of cores enabled. Value must be a multiple of 25%. If the requested percentage results in a fractional number of cores, the system rounds up the number of cores across processors and provisions an instance with a whole number of cores. - If the applications that you run on the instance use a core-based licensing model and need fewer cores than the full size of the shape, you can disable cores to reduce your licensing costs. The instance itself is billed for the full shape, regardless of whether all cores are enabled. 
- Type string
- The type of action to run when the instance is interrupted for eviction.
- AreVirtual boolInstructions Enabled 
- Whether virtualization instructions are available. For example, Secure Virtual Machine for AMD shapes or VT-x for Intel shapes.
- ConfigMap map[string]interface{}
- Instance Platform Configuration Configuration Map for flexible setting input.
- IsAccess boolControl Service Enabled 
- Whether the Access Control Service is enabled on the instance. When enabled, the platform can enforce PCIe device isolation, required for VFIO device pass-through.
- IsInput boolOutput Memory Management Unit Enabled 
- Whether the input-output memory management unit is enabled.
- IsMeasured boolBoot Enabled 
- Whether the Measured Boot feature is enabled on the instance.
- IsMemory boolEncryption Enabled 
- Whether the instance is a confidential instance. If this value is true, the instance is a confidential instance. The default value isfalse.
- IsSecure boolBoot Enabled 
- Whether Secure Boot is enabled on the instance.
- IsSymmetric boolMulti Threading Enabled 
- Whether symmetric multithreading is enabled on the instance. Symmetric multithreading is also called simultaneous multithreading (SMT) or Intel Hyper-Threading.
- IsTrusted boolPlatform Module Enabled 
- Whether the Trusted Platform Module (TPM) is enabled on the instance.
- NumaNodes stringPer Socket 
- The number of NUMA nodes per socket (NPS).
- PercentageOf intCores Enabled 
- The percentage of cores enabled. Value must be a multiple of 25%. If the requested percentage results in a fractional number of cores, the system rounds up the number of cores across processors and provisions an instance with a whole number of cores. - If the applications that you run on the instance use a core-based licensing model and need fewer cores than the full size of the shape, you can disable cores to reduce your licensing costs. The instance itself is billed for the full shape, regardless of whether all cores are enabled. 
- type String
- The type of action to run when the instance is interrupted for eviction.
- areVirtual BooleanInstructions Enabled 
- Whether virtualization instructions are available. For example, Secure Virtual Machine for AMD shapes or VT-x for Intel shapes.
- configMap Map<String,Object>
- Instance Platform Configuration Configuration Map for flexible setting input.
- isAccess BooleanControl Service Enabled 
- Whether the Access Control Service is enabled on the instance. When enabled, the platform can enforce PCIe device isolation, required for VFIO device pass-through.
- isInput BooleanOutput Memory Management Unit Enabled 
- Whether the input-output memory management unit is enabled.
- isMeasured BooleanBoot Enabled 
- Whether the Measured Boot feature is enabled on the instance.
- isMemory BooleanEncryption Enabled 
- Whether the instance is a confidential instance. If this value is true, the instance is a confidential instance. The default value isfalse.
- isSecure BooleanBoot Enabled 
- Whether Secure Boot is enabled on the instance.
- isSymmetric BooleanMulti Threading Enabled 
- Whether symmetric multithreading is enabled on the instance. Symmetric multithreading is also called simultaneous multithreading (SMT) or Intel Hyper-Threading.
- isTrusted BooleanPlatform Module Enabled 
- Whether the Trusted Platform Module (TPM) is enabled on the instance.
- numaNodes StringPer Socket 
- The number of NUMA nodes per socket (NPS).
- percentageOf IntegerCores Enabled 
- The percentage of cores enabled. Value must be a multiple of 25%. If the requested percentage results in a fractional number of cores, the system rounds up the number of cores across processors and provisions an instance with a whole number of cores. - If the applications that you run on the instance use a core-based licensing model and need fewer cores than the full size of the shape, you can disable cores to reduce your licensing costs. The instance itself is billed for the full shape, regardless of whether all cores are enabled. 
- type string
- The type of action to run when the instance is interrupted for eviction.
- areVirtual booleanInstructions Enabled 
- Whether virtualization instructions are available. For example, Secure Virtual Machine for AMD shapes or VT-x for Intel shapes.
- configMap {[key: string]: any}
- Instance Platform Configuration Configuration Map for flexible setting input.
- isAccess booleanControl Service Enabled 
- Whether the Access Control Service is enabled on the instance. When enabled, the platform can enforce PCIe device isolation, required for VFIO device pass-through.
- isInput booleanOutput Memory Management Unit Enabled 
- Whether the input-output memory management unit is enabled.
- isMeasured booleanBoot Enabled 
- Whether the Measured Boot feature is enabled on the instance.
- isMemory booleanEncryption Enabled 
- Whether the instance is a confidential instance. If this value is true, the instance is a confidential instance. The default value isfalse.
- isSecure booleanBoot Enabled 
- Whether Secure Boot is enabled on the instance.
- isSymmetric booleanMulti Threading Enabled 
- Whether symmetric multithreading is enabled on the instance. Symmetric multithreading is also called simultaneous multithreading (SMT) or Intel Hyper-Threading.
- isTrusted booleanPlatform Module Enabled 
- Whether the Trusted Platform Module (TPM) is enabled on the instance.
- numaNodes stringPer Socket 
- The number of NUMA nodes per socket (NPS).
- percentageOf numberCores Enabled 
- The percentage of cores enabled. Value must be a multiple of 25%. If the requested percentage results in a fractional number of cores, the system rounds up the number of cores across processors and provisions an instance with a whole number of cores. - If the applications that you run on the instance use a core-based licensing model and need fewer cores than the full size of the shape, you can disable cores to reduce your licensing costs. The instance itself is billed for the full shape, regardless of whether all cores are enabled. 
- type str
- The type of action to run when the instance is interrupted for eviction.
- are_virtual_ boolinstructions_ enabled 
- Whether virtualization instructions are available. For example, Secure Virtual Machine for AMD shapes or VT-x for Intel shapes.
- config_map Mapping[str, Any]
- Instance Platform Configuration Configuration Map for flexible setting input.
- is_access_ boolcontrol_ service_ enabled 
- Whether the Access Control Service is enabled on the instance. When enabled, the platform can enforce PCIe device isolation, required for VFIO device pass-through.
- is_input_ booloutput_ memory_ management_ unit_ enabled 
- Whether the input-output memory management unit is enabled.
- is_measured_ boolboot_ enabled 
- Whether the Measured Boot feature is enabled on the instance.
- is_memory_ boolencryption_ enabled 
- Whether the instance is a confidential instance. If this value is true, the instance is a confidential instance. The default value isfalse.
- is_secure_ boolboot_ enabled 
- Whether Secure Boot is enabled on the instance.
- is_symmetric_ boolmulti_ threading_ enabled 
- Whether symmetric multithreading is enabled on the instance. Symmetric multithreading is also called simultaneous multithreading (SMT) or Intel Hyper-Threading.
- is_trusted_ boolplatform_ module_ enabled 
- Whether the Trusted Platform Module (TPM) is enabled on the instance.
- numa_nodes_ strper_ socket 
- The number of NUMA nodes per socket (NPS).
- percentage_of_ intcores_ enabled 
- The percentage of cores enabled. Value must be a multiple of 25%. If the requested percentage results in a fractional number of cores, the system rounds up the number of cores across processors and provisions an instance with a whole number of cores. - If the applications that you run on the instance use a core-based licensing model and need fewer cores than the full size of the shape, you can disable cores to reduce your licensing costs. The instance itself is billed for the full shape, regardless of whether all cores are enabled. 
- type String
- The type of action to run when the instance is interrupted for eviction.
- areVirtual BooleanInstructions Enabled 
- Whether virtualization instructions are available. For example, Secure Virtual Machine for AMD shapes or VT-x for Intel shapes.
- configMap Map<Any>
- Instance Platform Configuration Configuration Map for flexible setting input.
- isAccess BooleanControl Service Enabled 
- Whether the Access Control Service is enabled on the instance. When enabled, the platform can enforce PCIe device isolation, required for VFIO device pass-through.
- isInput BooleanOutput Memory Management Unit Enabled 
- Whether the input-output memory management unit is enabled.
- isMeasured BooleanBoot Enabled 
- Whether the Measured Boot feature is enabled on the instance.
- isMemory BooleanEncryption Enabled 
- Whether the instance is a confidential instance. If this value is true, the instance is a confidential instance. The default value isfalse.
- isSecure BooleanBoot Enabled 
- Whether Secure Boot is enabled on the instance.
- isSymmetric BooleanMulti Threading Enabled 
- Whether symmetric multithreading is enabled on the instance. Symmetric multithreading is also called simultaneous multithreading (SMT) or Intel Hyper-Threading.
- isTrusted BooleanPlatform Module Enabled 
- Whether the Trusted Platform Module (TPM) is enabled on the instance.
- numaNodes StringPer Socket 
- The number of NUMA nodes per socket (NPS).
- percentageOf NumberCores Enabled 
- The percentage of cores enabled. Value must be a multiple of 25%. If the requested percentage results in a fractional number of cores, the system rounds up the number of cores across processors and provisions an instance with a whole number of cores. - If the applications that you run on the instance use a core-based licensing model and need fewer cores than the full size of the shape, you can disable cores to reduce your licensing costs. The instance itself is billed for the full shape, regardless of whether all cores are enabled. 
InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfig, InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigArgs                  
- PreemptionAction InstanceConfiguration Instance Details Launch Details Preemptible Instance Config Preemption Action 
- The action to run when the preemptible instance is interrupted for eviction.
- PreemptionAction InstanceConfiguration Instance Details Launch Details Preemptible Instance Config Preemption Action 
- The action to run when the preemptible instance is interrupted for eviction.
- preemptionAction InstanceConfiguration Instance Details Launch Details Preemptible Instance Config Preemption Action 
- The action to run when the preemptible instance is interrupted for eviction.
- preemptionAction InstanceConfiguration Instance Details Launch Details Preemptible Instance Config Preemption Action 
- The action to run when the preemptible instance is interrupted for eviction.
- preemption_action core.Instance Configuration Instance Details Launch Details Preemptible Instance Config Preemption Action 
- The action to run when the preemptible instance is interrupted for eviction.
- preemptionAction Property Map
- The action to run when the preemptible instance is interrupted for eviction.
InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionAction, InstanceConfigurationInstanceDetailsLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs                      
- Type string
- The type of action to run when the instance is interrupted for eviction.
- PreserveBoot boolVolume 
- Whether to preserve the boot volume that was used to launch the preemptible instance when the instance is terminated. Defaults to false if not specified.
- Type string
- The type of action to run when the instance is interrupted for eviction.
- PreserveBoot boolVolume 
- Whether to preserve the boot volume that was used to launch the preemptible instance when the instance is terminated. Defaults to false if not specified.
- type String
- The type of action to run when the instance is interrupted for eviction.
- preserveBoot BooleanVolume 
- Whether to preserve the boot volume that was used to launch the preemptible instance when the instance is terminated. Defaults to false if not specified.
- type string
- The type of action to run when the instance is interrupted for eviction.
- preserveBoot booleanVolume 
- Whether to preserve the boot volume that was used to launch the preemptible instance when the instance is terminated. Defaults to false if not specified.
- type str
- The type of action to run when the instance is interrupted for eviction.
- preserve_boot_ boolvolume 
- Whether to preserve the boot volume that was used to launch the preemptible instance when the instance is terminated. Defaults to false if not specified.
- type String
- The type of action to run when the instance is interrupted for eviction.
- preserveBoot BooleanVolume 
- Whether to preserve the boot volume that was used to launch the preemptible instance when the instance is terminated. Defaults to false if not specified.
InstanceConfigurationInstanceDetailsLaunchDetailsShapeConfig, InstanceConfigurationInstanceDetailsLaunchDetailsShapeConfigArgs                
- BaselineOcpu stringUtilization 
- The baseline OCPU utilization for a subcore burstable VM instance. Leave this attribute blank for a non-burstable instance, or explicitly specify non-burstable with BASELINE_1_1.
- MemoryIn doubleGbs 
- The total amount of memory available to the instance, in gigabytes.
- Nvmes int
- The number of NVMe drives to be used for storage. A single drive has 6.8 TB available.
- Ocpus double
- The total number of OCPUs available to the instance.
- Vcpus int
- The total number of VCPUs available to the instance. This can be used instead of OCPUs, in which case the actual number of OCPUs will be calculated based on this value and the actual hardware. This must be a multiple of 2.
- BaselineOcpu stringUtilization 
- The baseline OCPU utilization for a subcore burstable VM instance. Leave this attribute blank for a non-burstable instance, or explicitly specify non-burstable with BASELINE_1_1.
- MemoryIn float64Gbs 
- The total amount of memory available to the instance, in gigabytes.
- Nvmes int
- The number of NVMe drives to be used for storage. A single drive has 6.8 TB available.
- Ocpus float64
- The total number of OCPUs available to the instance.
- Vcpus int
- The total number of VCPUs available to the instance. This can be used instead of OCPUs, in which case the actual number of OCPUs will be calculated based on this value and the actual hardware. This must be a multiple of 2.
- baselineOcpu StringUtilization 
- The baseline OCPU utilization for a subcore burstable VM instance. Leave this attribute blank for a non-burstable instance, or explicitly specify non-burstable with BASELINE_1_1.
- memoryIn DoubleGbs 
- The total amount of memory available to the instance, in gigabytes.
- nvmes Integer
- The number of NVMe drives to be used for storage. A single drive has 6.8 TB available.
- ocpus Double
- The total number of OCPUs available to the instance.
- vcpus Integer
- The total number of VCPUs available to the instance. This can be used instead of OCPUs, in which case the actual number of OCPUs will be calculated based on this value and the actual hardware. This must be a multiple of 2.
- baselineOcpu stringUtilization 
- The baseline OCPU utilization for a subcore burstable VM instance. Leave this attribute blank for a non-burstable instance, or explicitly specify non-burstable with BASELINE_1_1.
- memoryIn numberGbs 
- The total amount of memory available to the instance, in gigabytes.
- nvmes number
- The number of NVMe drives to be used for storage. A single drive has 6.8 TB available.
- ocpus number
- The total number of OCPUs available to the instance.
- vcpus number
- The total number of VCPUs available to the instance. This can be used instead of OCPUs, in which case the actual number of OCPUs will be calculated based on this value and the actual hardware. This must be a multiple of 2.
- baseline_ocpu_ strutilization 
- The baseline OCPU utilization for a subcore burstable VM instance. Leave this attribute blank for a non-burstable instance, or explicitly specify non-burstable with BASELINE_1_1.
- memory_in_ floatgbs 
- The total amount of memory available to the instance, in gigabytes.
- nvmes int
- The number of NVMe drives to be used for storage. A single drive has 6.8 TB available.
- ocpus float
- The total number of OCPUs available to the instance.
- vcpus int
- The total number of VCPUs available to the instance. This can be used instead of OCPUs, in which case the actual number of OCPUs will be calculated based on this value and the actual hardware. This must be a multiple of 2.
- baselineOcpu StringUtilization 
- The baseline OCPU utilization for a subcore burstable VM instance. Leave this attribute blank for a non-burstable instance, or explicitly specify non-burstable with BASELINE_1_1.
- memoryIn NumberGbs 
- The total amount of memory available to the instance, in gigabytes.
- nvmes Number
- The number of NVMe drives to be used for storage. A single drive has 6.8 TB available.
- ocpus Number
- The total number of OCPUs available to the instance.
- vcpus Number
- The total number of VCPUs available to the instance. This can be used instead of OCPUs, in which case the actual number of OCPUs will be calculated based on this value and the actual hardware. This must be a multiple of 2.
InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetails, InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsArgs                
- SourceType string
- The source type for the instance. Use imagewhen specifying the image OCID. UsebootVolumewhen specifying the boot volume OCID.
- BootVolume stringId 
- The OCID of the boot volume used to boot the instance.
- BootVolume stringSize In Gbs 
- The size of the boot volume in GBs. The minimum value is 50 GB and the maximum value is 32,768 GB (32 TB).
- BootVolume stringVpus Per Gb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- ImageId string
- The OCID of the image used to boot the instance.
- InstanceSource InstanceImage Filter Details Configuration Instance Details Launch Details Source Details Instance Source Image Filter Details 
- These are the criteria for selecting an image. This is required if imageId is not specified.
- KmsKey stringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- SourceType string
- The source type for the instance. Use imagewhen specifying the image OCID. UsebootVolumewhen specifying the boot volume OCID.
- BootVolume stringId 
- The OCID of the boot volume used to boot the instance.
- BootVolume stringSize In Gbs 
- The size of the boot volume in GBs. The minimum value is 50 GB and the maximum value is 32,768 GB (32 TB).
- BootVolume stringVpus Per Gb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- ImageId string
- The OCID of the image used to boot the instance.
- InstanceSource InstanceImage Filter Details Configuration Instance Details Launch Details Source Details Instance Source Image Filter Details 
- These are the criteria for selecting an image. This is required if imageId is not specified.
- KmsKey stringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- sourceType String
- The source type for the instance. Use imagewhen specifying the image OCID. UsebootVolumewhen specifying the boot volume OCID.
- bootVolume StringId 
- The OCID of the boot volume used to boot the instance.
- bootVolume StringSize In Gbs 
- The size of the boot volume in GBs. The minimum value is 50 GB and the maximum value is 32,768 GB (32 TB).
- bootVolume StringVpus Per Gb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- imageId String
- The OCID of the image used to boot the instance.
- instanceSource InstanceImage Filter Details Configuration Instance Details Launch Details Source Details Instance Source Image Filter Details 
- These are the criteria for selecting an image. This is required if imageId is not specified.
- kmsKey StringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- sourceType string
- The source type for the instance. Use imagewhen specifying the image OCID. UsebootVolumewhen specifying the boot volume OCID.
- bootVolume stringId 
- The OCID of the boot volume used to boot the instance.
- bootVolume stringSize In Gbs 
- The size of the boot volume in GBs. The minimum value is 50 GB and the maximum value is 32,768 GB (32 TB).
- bootVolume stringVpus Per Gb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- imageId string
- The OCID of the image used to boot the instance.
- instanceSource InstanceImage Filter Details Configuration Instance Details Launch Details Source Details Instance Source Image Filter Details 
- These are the criteria for selecting an image. This is required if imageId is not specified.
- kmsKey stringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- source_type str
- The source type for the instance. Use imagewhen specifying the image OCID. UsebootVolumewhen specifying the boot volume OCID.
- boot_volume_ strid 
- The OCID of the boot volume used to boot the instance.
- boot_volume_ strsize_ in_ gbs 
- The size of the boot volume in GBs. The minimum value is 50 GB and the maximum value is 32,768 GB (32 TB).
- boot_volume_ strvpus_ per_ gb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- image_id str
- The OCID of the image used to boot the instance.
- instance_source_ core.image_ filter_ details Instance Configuration Instance Details Launch Details Source Details Instance Source Image Filter Details 
- These are the criteria for selecting an image. This is required if imageId is not specified.
- kms_key_ strid 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- sourceType String
- The source type for the instance. Use imagewhen specifying the image OCID. UsebootVolumewhen specifying the boot volume OCID.
- bootVolume StringId 
- The OCID of the boot volume used to boot the instance.
- bootVolume StringSize In Gbs 
- The size of the boot volume in GBs. The minimum value is 50 GB and the maximum value is 32,768 GB (32 TB).
- bootVolume StringVpus Per Gb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- imageId String
- The OCID of the image used to boot the instance.
- instanceSource Property MapImage Filter Details 
- These are the criteria for selecting an image. This is required if imageId is not specified.
- kmsKey StringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetails, InstanceConfigurationInstanceDetailsLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs                          
- CompartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- Dictionary<string, object>
- Filter based on these defined tags. Each key is predefined and scoped to a namespace. For more information, see Resource Tags.
- OperatingSystem string
- The image's operating system. Example: Oracle Linux
- OperatingSystem stringVersion 
- The image's operating system version. Example: 7.2
- CompartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- map[string]interface{}
- Filter based on these defined tags. Each key is predefined and scoped to a namespace. For more information, see Resource Tags.
- OperatingSystem string
- The image's operating system. Example: Oracle Linux
- OperatingSystem stringVersion 
- The image's operating system version. Example: 7.2
- compartmentId String
- (Updatable) The OCID of the compartment containing the instance configuration.
- Map<String,Object>
- Filter based on these defined tags. Each key is predefined and scoped to a namespace. For more information, see Resource Tags.
- operatingSystem String
- The image's operating system. Example: Oracle Linux
- operatingSystem StringVersion 
- The image's operating system version. Example: 7.2
- compartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- {[key: string]: any}
- Filter based on these defined tags. Each key is predefined and scoped to a namespace. For more information, see Resource Tags.
- operatingSystem string
- The image's operating system. Example: Oracle Linux
- operatingSystem stringVersion 
- The image's operating system version. Example: 7.2
- compartment_id str
- (Updatable) The OCID of the compartment containing the instance configuration.
- Mapping[str, Any]
- Filter based on these defined tags. Each key is predefined and scoped to a namespace. For more information, see Resource Tags.
- operating_system str
- The image's operating system. Example: Oracle Linux
- operating_system_ strversion 
- The image's operating system version. Example: 7.2
- compartmentId String
- (Updatable) The OCID of the compartment containing the instance configuration.
- Map<Any>
- Filter based on these defined tags. Each key is predefined and scoped to a namespace. For more information, see Resource Tags.
- operatingSystem String
- The image's operating system. Example: Oracle Linux
- operatingSystem StringVersion 
- The image's operating system version. Example: 7.2
InstanceConfigurationInstanceDetailsOption, InstanceConfigurationInstanceDetailsOptionArgs          
- BlockVolumes List<InstanceConfiguration Instance Details Option Block Volume> 
- Block volume parameters.
- LaunchDetails InstanceConfiguration Instance Details Option Launch Details 
- Instance launch details for creating an instance from an instance configuration. Use the sourceDetailsparameter to specify whether a boot volume or an image should be used to launch a new instance.
- SecondaryVnics List<InstanceConfiguration Instance Details Option Secondary Vnic> 
- Secondary VNIC parameters.
- BlockVolumes []InstanceConfiguration Instance Details Option Block Volume 
- Block volume parameters.
- LaunchDetails InstanceConfiguration Instance Details Option Launch Details 
- Instance launch details for creating an instance from an instance configuration. Use the sourceDetailsparameter to specify whether a boot volume or an image should be used to launch a new instance.
- SecondaryVnics []InstanceConfiguration Instance Details Option Secondary Vnic 
- Secondary VNIC parameters.
- blockVolumes List<InstanceConfiguration Instance Details Option Block Volume> 
- Block volume parameters.
- launchDetails InstanceConfiguration Instance Details Option Launch Details 
- Instance launch details for creating an instance from an instance configuration. Use the sourceDetailsparameter to specify whether a boot volume or an image should be used to launch a new instance.
- secondaryVnics List<InstanceConfiguration Instance Details Option Secondary Vnic> 
- Secondary VNIC parameters.
- blockVolumes InstanceConfiguration Instance Details Option Block Volume[] 
- Block volume parameters.
- launchDetails InstanceConfiguration Instance Details Option Launch Details 
- Instance launch details for creating an instance from an instance configuration. Use the sourceDetailsparameter to specify whether a boot volume or an image should be used to launch a new instance.
- secondaryVnics InstanceConfiguration Instance Details Option Secondary Vnic[] 
- Secondary VNIC parameters.
- block_volumes Sequence[core.Instance Configuration Instance Details Option Block Volume] 
- Block volume parameters.
- launch_details core.Instance Configuration Instance Details Option Launch Details 
- Instance launch details for creating an instance from an instance configuration. Use the sourceDetailsparameter to specify whether a boot volume or an image should be used to launch a new instance.
- secondary_vnics Sequence[core.Instance Configuration Instance Details Option Secondary Vnic] 
- Secondary VNIC parameters.
- blockVolumes List<Property Map>
- Block volume parameters.
- launchDetails Property Map
- Instance launch details for creating an instance from an instance configuration. Use the sourceDetailsparameter to specify whether a boot volume or an image should be used to launch a new instance.
- secondaryVnics List<Property Map>
- Secondary VNIC parameters.
InstanceConfigurationInstanceDetailsOptionBlockVolume, InstanceConfigurationInstanceDetailsOptionBlockVolumeArgs              
- AttachDetails InstanceConfiguration Instance Details Option Block Volume Attach Details 
- Volume attachmentDetails. Please see AttachVolumeDetails
- CreateDetails InstanceConfiguration Instance Details Option Block Volume Create Details 
- Creates a new block volume. Please see CreateVolumeDetails
- VolumeId string
- The OCID of the volume.
- AttachDetails InstanceConfiguration Instance Details Option Block Volume Attach Details 
- Volume attachmentDetails. Please see AttachVolumeDetails
- CreateDetails InstanceConfiguration Instance Details Option Block Volume Create Details 
- Creates a new block volume. Please see CreateVolumeDetails
- VolumeId string
- The OCID of the volume.
- attachDetails InstanceConfiguration Instance Details Option Block Volume Attach Details 
- Volume attachmentDetails. Please see AttachVolumeDetails
- createDetails InstanceConfiguration Instance Details Option Block Volume Create Details 
- Creates a new block volume. Please see CreateVolumeDetails
- volumeId String
- The OCID of the volume.
- attachDetails InstanceConfiguration Instance Details Option Block Volume Attach Details 
- Volume attachmentDetails. Please see AttachVolumeDetails
- createDetails InstanceConfiguration Instance Details Option Block Volume Create Details 
- Creates a new block volume. Please see CreateVolumeDetails
- volumeId string
- The OCID of the volume.
- attach_details core.Instance Configuration Instance Details Option Block Volume Attach Details 
- Volume attachmentDetails. Please see AttachVolumeDetails
- create_details core.Instance Configuration Instance Details Option Block Volume Create Details 
- Creates a new block volume. Please see CreateVolumeDetails
- volume_id str
- The OCID of the volume.
- attachDetails Property Map
- Volume attachmentDetails. Please see AttachVolumeDetails
- createDetails Property Map
- Creates a new block volume. Please see CreateVolumeDetails
- volumeId String
- The OCID of the volume.
InstanceConfigurationInstanceDetailsOptionBlockVolumeAttachDetails, InstanceConfigurationInstanceDetailsOptionBlockVolumeAttachDetailsArgs                  
- Type string
- The type of action to run when the instance is interrupted for eviction.
- Device string
- The device name.
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- IsPv boolEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- IsRead boolOnly 
- Whether the attachment should be created in read-only mode.
- bool
- Whether the attachment should be created in shareable mode. If an attachment is created in shareable mode, then other instances can attach the same volume, provided that they also create their attachments in shareable mode. Only certain volume types can be attached in shareable mode. Defaults to false if not specified.
- UseChap bool
- Whether to use CHAP authentication for the volume attachment. Defaults to false.
- Type string
- The type of action to run when the instance is interrupted for eviction.
- Device string
- The device name.
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- IsPv boolEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- IsRead boolOnly 
- Whether the attachment should be created in read-only mode.
- bool
- Whether the attachment should be created in shareable mode. If an attachment is created in shareable mode, then other instances can attach the same volume, provided that they also create their attachments in shareable mode. Only certain volume types can be attached in shareable mode. Defaults to false if not specified.
- UseChap bool
- Whether to use CHAP authentication for the volume attachment. Defaults to false.
- type String
- The type of action to run when the instance is interrupted for eviction.
- device String
- The device name.
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- isPv BooleanEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- isRead BooleanOnly 
- Whether the attachment should be created in read-only mode.
- Boolean
- Whether the attachment should be created in shareable mode. If an attachment is created in shareable mode, then other instances can attach the same volume, provided that they also create their attachments in shareable mode. Only certain volume types can be attached in shareable mode. Defaults to false if not specified.
- useChap Boolean
- Whether to use CHAP authentication for the volume attachment. Defaults to false.
- type string
- The type of action to run when the instance is interrupted for eviction.
- device string
- The device name.
- displayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- isPv booleanEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- isRead booleanOnly 
- Whether the attachment should be created in read-only mode.
- boolean
- Whether the attachment should be created in shareable mode. If an attachment is created in shareable mode, then other instances can attach the same volume, provided that they also create their attachments in shareable mode. Only certain volume types can be attached in shareable mode. Defaults to false if not specified.
- useChap boolean
- Whether to use CHAP authentication for the volume attachment. Defaults to false.
- type str
- The type of action to run when the instance is interrupted for eviction.
- device str
- The device name.
- display_name str
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- is_pv_ boolencryption_ in_ transit_ enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- is_read_ boolonly 
- Whether the attachment should be created in read-only mode.
- bool
- Whether the attachment should be created in shareable mode. If an attachment is created in shareable mode, then other instances can attach the same volume, provided that they also create their attachments in shareable mode. Only certain volume types can be attached in shareable mode. Defaults to false if not specified.
- use_chap bool
- Whether to use CHAP authentication for the volume attachment. Defaults to false.
- type String
- The type of action to run when the instance is interrupted for eviction.
- device String
- The device name.
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- isPv BooleanEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- isRead BooleanOnly 
- Whether the attachment should be created in read-only mode.
- Boolean
- Whether the attachment should be created in shareable mode. If an attachment is created in shareable mode, then other instances can attach the same volume, provided that they also create their attachments in shareable mode. Only certain volume types can be attached in shareable mode. Defaults to false if not specified.
- useChap Boolean
- Whether to use CHAP authentication for the volume attachment. Defaults to false.
InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetails, InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsArgs                  
- AutotunePolicies List<InstanceConfiguration Instance Details Option Block Volume Create Details Autotune Policy> 
- The list of autotune policies enabled for this volume.
- AvailabilityDomain string
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- BackupPolicy stringId 
- If provided, specifies the ID of the volume backup policy to assign to the newly created volume. If omitted, no policy will be assigned.
- BlockVolume InstanceReplicas Configuration Instance Details Option Block Volume Create Details Block Volume Replicas 
- The list of block volume replicas to be enabled for this volume in the specified destination availability domains.
- ClusterPlacement stringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- CompartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- Dictionary<string, object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Dictionary<string, object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- IsAuto boolTune Enabled 
- Specifies whether the auto-tune performance is enabled for this boot volume. This field is deprecated. Use the InstanceConfigurationDetachedVolumeAutotunePolicyinstead to enable the volume for detached autotune.
- KmsKey stringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- SizeIn stringGbs 
- The size of the volume in GBs.
- SourceDetails InstanceConfiguration Instance Details Option Block Volume Create Details Source Details 
- VpusPer stringGb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- AutotunePolicies []InstanceConfiguration Instance Details Option Block Volume Create Details Autotune Policy 
- The list of autotune policies enabled for this volume.
- AvailabilityDomain string
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- BackupPolicy stringId 
- If provided, specifies the ID of the volume backup policy to assign to the newly created volume. If omitted, no policy will be assigned.
- BlockVolume InstanceReplicas Configuration Instance Details Option Block Volume Create Details Block Volume Replicas 
- The list of block volume replicas to be enabled for this volume in the specified destination availability domains.
- ClusterPlacement stringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- CompartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- map[string]interface{}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- map[string]interface{}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- IsAuto boolTune Enabled 
- Specifies whether the auto-tune performance is enabled for this boot volume. This field is deprecated. Use the InstanceConfigurationDetachedVolumeAutotunePolicyinstead to enable the volume for detached autotune.
- KmsKey stringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- SizeIn stringGbs 
- The size of the volume in GBs.
- SourceDetails InstanceConfiguration Instance Details Option Block Volume Create Details Source Details 
- VpusPer stringGb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- autotunePolicies List<InstanceConfiguration Instance Details Option Block Volume Create Details Autotune Policy> 
- The list of autotune policies enabled for this volume.
- availabilityDomain String
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- backupPolicy StringId 
- If provided, specifies the ID of the volume backup policy to assign to the newly created volume. If omitted, no policy will be assigned.
- blockVolume InstanceReplicas Configuration Instance Details Option Block Volume Create Details Block Volume Replicas 
- The list of block volume replicas to be enabled for this volume in the specified destination availability domains.
- clusterPlacement StringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartmentId String
- (Updatable) The OCID of the compartment containing the instance configuration.
- Map<String,Object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<String,Object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- isAuto BooleanTune Enabled 
- Specifies whether the auto-tune performance is enabled for this boot volume. This field is deprecated. Use the InstanceConfigurationDetachedVolumeAutotunePolicyinstead to enable the volume for detached autotune.
- kmsKey StringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- sizeIn StringGbs 
- The size of the volume in GBs.
- sourceDetails InstanceConfiguration Instance Details Option Block Volume Create Details Source Details 
- vpusPer StringGb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- autotunePolicies InstanceConfiguration Instance Details Option Block Volume Create Details Autotune Policy[] 
- The list of autotune policies enabled for this volume.
- availabilityDomain string
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- backupPolicy stringId 
- If provided, specifies the ID of the volume backup policy to assign to the newly created volume. If omitted, no policy will be assigned.
- blockVolume InstanceReplicas Configuration Instance Details Option Block Volume Create Details Block Volume Replicas 
- The list of block volume replicas to be enabled for this volume in the specified destination availability domains.
- clusterPlacement stringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- {[key: string]: any}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- {[key: string]: any}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- isAuto booleanTune Enabled 
- Specifies whether the auto-tune performance is enabled for this boot volume. This field is deprecated. Use the InstanceConfigurationDetachedVolumeAutotunePolicyinstead to enable the volume for detached autotune.
- kmsKey stringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- sizeIn stringGbs 
- The size of the volume in GBs.
- sourceDetails InstanceConfiguration Instance Details Option Block Volume Create Details Source Details 
- vpusPer stringGb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- autotune_policies Sequence[core.Instance Configuration Instance Details Option Block Volume Create Details Autotune Policy] 
- The list of autotune policies enabled for this volume.
- availability_domain str
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- backup_policy_ strid 
- If provided, specifies the ID of the volume backup policy to assign to the newly created volume. If omitted, no policy will be assigned.
- block_volume_ core.replicas Instance Configuration Instance Details Option Block Volume Create Details Block Volume Replicas 
- The list of block volume replicas to be enabled for this volume in the specified destination availability domains.
- cluster_placement_ strgroup_ id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartment_id str
- (Updatable) The OCID of the compartment containing the instance configuration.
- Mapping[str, Any]
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- display_name str
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Mapping[str, Any]
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- is_auto_ booltune_ enabled 
- Specifies whether the auto-tune performance is enabled for this boot volume. This field is deprecated. Use the InstanceConfigurationDetachedVolumeAutotunePolicyinstead to enable the volume for detached autotune.
- kms_key_ strid 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- size_in_ strgbs 
- The size of the volume in GBs.
- source_details core.Instance Configuration Instance Details Option Block Volume Create Details Source Details 
- vpus_per_ strgb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- autotunePolicies List<Property Map>
- The list of autotune policies enabled for this volume.
- availabilityDomain String
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- backupPolicy StringId 
- If provided, specifies the ID of the volume backup policy to assign to the newly created volume. If omitted, no policy will be assigned.
- blockVolume Property MapReplicas 
- The list of block volume replicas to be enabled for this volume in the specified destination availability domains.
- clusterPlacement StringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartmentId String
- (Updatable) The OCID of the compartment containing the instance configuration.
- Map<Any>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<Any>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- isAuto BooleanTune Enabled 
- Specifies whether the auto-tune performance is enabled for this boot volume. This field is deprecated. Use the InstanceConfigurationDetachedVolumeAutotunePolicyinstead to enable the volume for detached autotune.
- kmsKey StringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- sizeIn StringGbs 
- The size of the volume in GBs.
- sourceDetails Property Map
- vpusPer StringGb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsAutotunePolicy, InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsAutotunePolicyArgs                      
- AutotuneType string
- This specifies the type of autotunes supported by OCI.
- MaxVpus stringPer Gb 
- This will be the maximum VPUs/GB performance level that the volume will be auto-tuned temporarily based on performance monitoring.
- AutotuneType string
- This specifies the type of autotunes supported by OCI.
- MaxVpus stringPer Gb 
- This will be the maximum VPUs/GB performance level that the volume will be auto-tuned temporarily based on performance monitoring.
- autotuneType String
- This specifies the type of autotunes supported by OCI.
- maxVpus StringPer Gb 
- This will be the maximum VPUs/GB performance level that the volume will be auto-tuned temporarily based on performance monitoring.
- autotuneType string
- This specifies the type of autotunes supported by OCI.
- maxVpus stringPer Gb 
- This will be the maximum VPUs/GB performance level that the volume will be auto-tuned temporarily based on performance monitoring.
- autotune_type str
- This specifies the type of autotunes supported by OCI.
- max_vpus_ strper_ gb 
- This will be the maximum VPUs/GB performance level that the volume will be auto-tuned temporarily based on performance monitoring.
- autotuneType String
- This specifies the type of autotunes supported by OCI.
- maxVpus StringPer Gb 
- This will be the maximum VPUs/GB performance level that the volume will be auto-tuned temporarily based on performance monitoring.
InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsBlockVolumeReplicas, InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsBlockVolumeReplicasArgs                        
- AvailabilityDomain string
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- AvailabilityDomain string
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- availabilityDomain String
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- availabilityDomain string
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- displayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- availability_domain str
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- display_name str
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- availabilityDomain String
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsSourceDetails, InstanceConfigurationInstanceDetailsOptionBlockVolumeCreateDetailsSourceDetailsArgs                      
InstanceConfigurationInstanceDetailsOptionLaunchDetails, InstanceConfigurationInstanceDetailsOptionLaunchDetailsArgs              
- AgentConfig InstanceConfiguration Instance Details Option Launch Details Agent Config 
- Configuration options for the Oracle Cloud Agent software running on the instance.
- AvailabilityConfig InstanceConfiguration Instance Details Option Launch Details Availability Config 
- Options for defining the availabiity of a VM instance after a maintenance event that impacts the underlying hardware.
- AvailabilityDomain string
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- CapacityReservation stringId 
- The OCID of the compute capacity reservation this instance is launched under.
- ClusterPlacement stringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- CompartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- CreateVnic InstanceDetails Configuration Instance Details Option Launch Details Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- DedicatedVm stringHost Id 
- The OCID of the dedicated virtual machine host to place the instance on.
- Dictionary<string, object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- ExtendedMetadata Dictionary<string, object>
- Additional metadata key/value pairs that you provide. They serve the same purpose and functionality as fields in the metadataobject.
- FaultDomain string
- A fault domain is a grouping of hardware and infrastructure within an availability domain. Each availability domain contains three fault domains. Fault domains let you distribute your instances so that they are not on the same physical hardware within a single availability domain. A hardware failure or Compute hardware maintenance that affects one fault domain does not affect instances in other fault domains.
- Dictionary<string, object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- InstanceOptions InstanceConfiguration Instance Details Option Launch Details Instance Options 
- Optional mutable instance options. As a part of Instance Metadata Service Security Header, This allows user to disable the legacy imds endpoints.
- IpxeScript string
- This is an advanced option.
- IsPv boolEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- LaunchMode string
- Specifies the configuration mode for launching virtual machine (VM) instances. The configuration modes are:- NATIVE- VM instances launch with iSCSI boot and VFIO devices. The default value for platform images.
- EMULATED- VM instances launch with emulated devices, such as the E1000 network driver and emulated SCSI disk controller.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
- CUSTOM- VM instances launch with custom configuration settings specified in the- LaunchOptionsparameter.
 
- LaunchOptions InstanceConfiguration Instance Details Option Launch Details Launch Options 
- Options for tuning the compatibility and performance of VM shapes. The values that you specify override any default values.
- Metadata Dictionary<string, object>
- Custom metadata key/value pairs that you provide, such as the SSH public key required to connect to the instance.
- PlatformConfig InstanceConfiguration Instance Details Option Launch Details Platform Config 
- The platform configuration requested for the instance.
- PreemptibleInstance InstanceConfig Configuration Instance Details Option Launch Details Preemptible Instance Config 
- Configuration options for preemptible instances.
- PreferredMaintenance stringAction 
- The preferred maintenance action for an instance. The default is LIVE_MIGRATE, if live migration is supported.- LIVE_MIGRATE- Run maintenance using a live migration.
- REBOOT- Run maintenance using a reboot.
 
- Shape string
- The shape of an instance. The shape determines the number of CPUs, amount of memory, and other resources allocated to the instance.
- ShapeConfig InstanceConfiguration Instance Details Option Launch Details Shape Config 
- The shape configuration requested for the instance.
- SourceDetails InstanceConfiguration Instance Details Option Launch Details Source Details 
- AgentConfig InstanceConfiguration Instance Details Option Launch Details Agent Config 
- Configuration options for the Oracle Cloud Agent software running on the instance.
- AvailabilityConfig InstanceConfiguration Instance Details Option Launch Details Availability Config 
- Options for defining the availabiity of a VM instance after a maintenance event that impacts the underlying hardware.
- AvailabilityDomain string
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- CapacityReservation stringId 
- The OCID of the compute capacity reservation this instance is launched under.
- ClusterPlacement stringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- CompartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- CreateVnic InstanceDetails Configuration Instance Details Option Launch Details Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- DedicatedVm stringHost Id 
- The OCID of the dedicated virtual machine host to place the instance on.
- map[string]interface{}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- ExtendedMetadata map[string]interface{}
- Additional metadata key/value pairs that you provide. They serve the same purpose and functionality as fields in the metadataobject.
- FaultDomain string
- A fault domain is a grouping of hardware and infrastructure within an availability domain. Each availability domain contains three fault domains. Fault domains let you distribute your instances so that they are not on the same physical hardware within a single availability domain. A hardware failure or Compute hardware maintenance that affects one fault domain does not affect instances in other fault domains.
- map[string]interface{}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- InstanceOptions InstanceConfiguration Instance Details Option Launch Details Instance Options 
- Optional mutable instance options. As a part of Instance Metadata Service Security Header, This allows user to disable the legacy imds endpoints.
- IpxeScript string
- This is an advanced option.
- IsPv boolEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- LaunchMode string
- Specifies the configuration mode for launching virtual machine (VM) instances. The configuration modes are:- NATIVE- VM instances launch with iSCSI boot and VFIO devices. The default value for platform images.
- EMULATED- VM instances launch with emulated devices, such as the E1000 network driver and emulated SCSI disk controller.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
- CUSTOM- VM instances launch with custom configuration settings specified in the- LaunchOptionsparameter.
 
- LaunchOptions InstanceConfiguration Instance Details Option Launch Details Launch Options 
- Options for tuning the compatibility and performance of VM shapes. The values that you specify override any default values.
- Metadata map[string]interface{}
- Custom metadata key/value pairs that you provide, such as the SSH public key required to connect to the instance.
- PlatformConfig InstanceConfiguration Instance Details Option Launch Details Platform Config 
- The platform configuration requested for the instance.
- PreemptibleInstance InstanceConfig Configuration Instance Details Option Launch Details Preemptible Instance Config 
- Configuration options for preemptible instances.
- PreferredMaintenance stringAction 
- The preferred maintenance action for an instance. The default is LIVE_MIGRATE, if live migration is supported.- LIVE_MIGRATE- Run maintenance using a live migration.
- REBOOT- Run maintenance using a reboot.
 
- Shape string
- The shape of an instance. The shape determines the number of CPUs, amount of memory, and other resources allocated to the instance.
- ShapeConfig InstanceConfiguration Instance Details Option Launch Details Shape Config 
- The shape configuration requested for the instance.
- SourceDetails InstanceConfiguration Instance Details Option Launch Details Source Details 
- agentConfig InstanceConfiguration Instance Details Option Launch Details Agent Config 
- Configuration options for the Oracle Cloud Agent software running on the instance.
- availabilityConfig InstanceConfiguration Instance Details Option Launch Details Availability Config 
- Options for defining the availabiity of a VM instance after a maintenance event that impacts the underlying hardware.
- availabilityDomain String
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- capacityReservation StringId 
- The OCID of the compute capacity reservation this instance is launched under.
- clusterPlacement StringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartmentId String
- (Updatable) The OCID of the compartment containing the instance configuration.
- createVnic InstanceDetails Configuration Instance Details Option Launch Details Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- dedicatedVm StringHost Id 
- The OCID of the dedicated virtual machine host to place the instance on.
- Map<String,Object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- extendedMetadata Map<String,Object>
- Additional metadata key/value pairs that you provide. They serve the same purpose and functionality as fields in the metadataobject.
- faultDomain String
- A fault domain is a grouping of hardware and infrastructure within an availability domain. Each availability domain contains three fault domains. Fault domains let you distribute your instances so that they are not on the same physical hardware within a single availability domain. A hardware failure or Compute hardware maintenance that affects one fault domain does not affect instances in other fault domains.
- Map<String,Object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instanceOptions InstanceConfiguration Instance Details Option Launch Details Instance Options 
- Optional mutable instance options. As a part of Instance Metadata Service Security Header, This allows user to disable the legacy imds endpoints.
- ipxeScript String
- This is an advanced option.
- isPv BooleanEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- launchMode String
- Specifies the configuration mode for launching virtual machine (VM) instances. The configuration modes are:- NATIVE- VM instances launch with iSCSI boot and VFIO devices. The default value for platform images.
- EMULATED- VM instances launch with emulated devices, such as the E1000 network driver and emulated SCSI disk controller.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
- CUSTOM- VM instances launch with custom configuration settings specified in the- LaunchOptionsparameter.
 
- launchOptions InstanceConfiguration Instance Details Option Launch Details Launch Options 
- Options for tuning the compatibility and performance of VM shapes. The values that you specify override any default values.
- metadata Map<String,Object>
- Custom metadata key/value pairs that you provide, such as the SSH public key required to connect to the instance.
- platformConfig InstanceConfiguration Instance Details Option Launch Details Platform Config 
- The platform configuration requested for the instance.
- preemptibleInstance InstanceConfig Configuration Instance Details Option Launch Details Preemptible Instance Config 
- Configuration options for preemptible instances.
- preferredMaintenance StringAction 
- The preferred maintenance action for an instance. The default is LIVE_MIGRATE, if live migration is supported.- LIVE_MIGRATE- Run maintenance using a live migration.
- REBOOT- Run maintenance using a reboot.
 
- shape String
- The shape of an instance. The shape determines the number of CPUs, amount of memory, and other resources allocated to the instance.
- shapeConfig InstanceConfiguration Instance Details Option Launch Details Shape Config 
- The shape configuration requested for the instance.
- sourceDetails InstanceConfiguration Instance Details Option Launch Details Source Details 
- agentConfig InstanceConfiguration Instance Details Option Launch Details Agent Config 
- Configuration options for the Oracle Cloud Agent software running on the instance.
- availabilityConfig InstanceConfiguration Instance Details Option Launch Details Availability Config 
- Options for defining the availabiity of a VM instance after a maintenance event that impacts the underlying hardware.
- availabilityDomain string
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- capacityReservation stringId 
- The OCID of the compute capacity reservation this instance is launched under.
- clusterPlacement stringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- createVnic InstanceDetails Configuration Instance Details Option Launch Details Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- dedicatedVm stringHost Id 
- The OCID of the dedicated virtual machine host to place the instance on.
- {[key: string]: any}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- extendedMetadata {[key: string]: any}
- Additional metadata key/value pairs that you provide. They serve the same purpose and functionality as fields in the metadataobject.
- faultDomain string
- A fault domain is a grouping of hardware and infrastructure within an availability domain. Each availability domain contains three fault domains. Fault domains let you distribute your instances so that they are not on the same physical hardware within a single availability domain. A hardware failure or Compute hardware maintenance that affects one fault domain does not affect instances in other fault domains.
- {[key: string]: any}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instanceOptions InstanceConfiguration Instance Details Option Launch Details Instance Options 
- Optional mutable instance options. As a part of Instance Metadata Service Security Header, This allows user to disable the legacy imds endpoints.
- ipxeScript string
- This is an advanced option.
- isPv booleanEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- launchMode string
- Specifies the configuration mode for launching virtual machine (VM) instances. The configuration modes are:- NATIVE- VM instances launch with iSCSI boot and VFIO devices. The default value for platform images.
- EMULATED- VM instances launch with emulated devices, such as the E1000 network driver and emulated SCSI disk controller.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
- CUSTOM- VM instances launch with custom configuration settings specified in the- LaunchOptionsparameter.
 
- launchOptions InstanceConfiguration Instance Details Option Launch Details Launch Options 
- Options for tuning the compatibility and performance of VM shapes. The values that you specify override any default values.
- metadata {[key: string]: any}
- Custom metadata key/value pairs that you provide, such as the SSH public key required to connect to the instance.
- platformConfig InstanceConfiguration Instance Details Option Launch Details Platform Config 
- The platform configuration requested for the instance.
- preemptibleInstance InstanceConfig Configuration Instance Details Option Launch Details Preemptible Instance Config 
- Configuration options for preemptible instances.
- preferredMaintenance stringAction 
- The preferred maintenance action for an instance. The default is LIVE_MIGRATE, if live migration is supported.- LIVE_MIGRATE- Run maintenance using a live migration.
- REBOOT- Run maintenance using a reboot.
 
- shape string
- The shape of an instance. The shape determines the number of CPUs, amount of memory, and other resources allocated to the instance.
- shapeConfig InstanceConfiguration Instance Details Option Launch Details Shape Config 
- The shape configuration requested for the instance.
- sourceDetails InstanceConfiguration Instance Details Option Launch Details Source Details 
- agent_config core.Instance Configuration Instance Details Option Launch Details Agent Config 
- Configuration options for the Oracle Cloud Agent software running on the instance.
- availability_config core.Instance Configuration Instance Details Option Launch Details Availability Config 
- Options for defining the availabiity of a VM instance after a maintenance event that impacts the underlying hardware.
- availability_domain str
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- capacity_reservation_ strid 
- The OCID of the compute capacity reservation this instance is launched under.
- cluster_placement_ strgroup_ id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartment_id str
- (Updatable) The OCID of the compartment containing the instance configuration.
- create_vnic_ core.details Instance Configuration Instance Details Option Launch Details Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- dedicated_vm_ strhost_ id 
- The OCID of the dedicated virtual machine host to place the instance on.
- Mapping[str, Any]
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- display_name str
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- extended_metadata Mapping[str, Any]
- Additional metadata key/value pairs that you provide. They serve the same purpose and functionality as fields in the metadataobject.
- fault_domain str
- A fault domain is a grouping of hardware and infrastructure within an availability domain. Each availability domain contains three fault domains. Fault domains let you distribute your instances so that they are not on the same physical hardware within a single availability domain. A hardware failure or Compute hardware maintenance that affects one fault domain does not affect instances in other fault domains.
- Mapping[str, Any]
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instance_options core.Instance Configuration Instance Details Option Launch Details Instance Options 
- Optional mutable instance options. As a part of Instance Metadata Service Security Header, This allows user to disable the legacy imds endpoints.
- ipxe_script str
- This is an advanced option.
- is_pv_ boolencryption_ in_ transit_ enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- launch_mode str
- Specifies the configuration mode for launching virtual machine (VM) instances. The configuration modes are:- NATIVE- VM instances launch with iSCSI boot and VFIO devices. The default value for platform images.
- EMULATED- VM instances launch with emulated devices, such as the E1000 network driver and emulated SCSI disk controller.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
- CUSTOM- VM instances launch with custom configuration settings specified in the- LaunchOptionsparameter.
 
- launch_options core.Instance Configuration Instance Details Option Launch Details Launch Options 
- Options for tuning the compatibility and performance of VM shapes. The values that you specify override any default values.
- metadata Mapping[str, Any]
- Custom metadata key/value pairs that you provide, such as the SSH public key required to connect to the instance.
- platform_config core.Instance Configuration Instance Details Option Launch Details Platform Config 
- The platform configuration requested for the instance.
- preemptible_instance_ core.config Instance Configuration Instance Details Option Launch Details Preemptible Instance Config 
- Configuration options for preemptible instances.
- preferred_maintenance_ straction 
- The preferred maintenance action for an instance. The default is LIVE_MIGRATE, if live migration is supported.- LIVE_MIGRATE- Run maintenance using a live migration.
- REBOOT- Run maintenance using a reboot.
 
- shape str
- The shape of an instance. The shape determines the number of CPUs, amount of memory, and other resources allocated to the instance.
- shape_config core.Instance Configuration Instance Details Option Launch Details Shape Config 
- The shape configuration requested for the instance.
- source_details core.Instance Configuration Instance Details Option Launch Details Source Details 
- agentConfig Property Map
- Configuration options for the Oracle Cloud Agent software running on the instance.
- availabilityConfig Property Map
- Options for defining the availabiity of a VM instance after a maintenance event that impacts the underlying hardware.
- availabilityDomain String
- The availability domain of the instance. Example: Uocm:PHX-AD-1
- capacityReservation StringId 
- The OCID of the compute capacity reservation this instance is launched under.
- clusterPlacement StringGroup Id 
- The clusterPlacementGroup Id of the volume for volume placement.
- compartmentId String
- (Updatable) The OCID of the compartment containing the instance configuration.
- createVnic Property MapDetails 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- dedicatedVm StringHost Id 
- The OCID of the dedicated virtual machine host to place the instance on.
- Map<Any>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- extendedMetadata Map<Any>
- Additional metadata key/value pairs that you provide. They serve the same purpose and functionality as fields in the metadataobject.
- faultDomain String
- A fault domain is a grouping of hardware and infrastructure within an availability domain. Each availability domain contains three fault domains. Fault domains let you distribute your instances so that they are not on the same physical hardware within a single availability domain. A hardware failure or Compute hardware maintenance that affects one fault domain does not affect instances in other fault domains.
- Map<Any>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- instanceOptions Property Map
- Optional mutable instance options. As a part of Instance Metadata Service Security Header, This allows user to disable the legacy imds endpoints.
- ipxeScript String
- This is an advanced option.
- isPv BooleanEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- launchMode String
- Specifies the configuration mode for launching virtual machine (VM) instances. The configuration modes are:- NATIVE- VM instances launch with iSCSI boot and VFIO devices. The default value for platform images.
- EMULATED- VM instances launch with emulated devices, such as the E1000 network driver and emulated SCSI disk controller.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
- CUSTOM- VM instances launch with custom configuration settings specified in the- LaunchOptionsparameter.
 
- launchOptions Property Map
- Options for tuning the compatibility and performance of VM shapes. The values that you specify override any default values.
- metadata Map<Any>
- Custom metadata key/value pairs that you provide, such as the SSH public key required to connect to the instance.
- platformConfig Property Map
- The platform configuration requested for the instance.
- preemptibleInstance Property MapConfig 
- Configuration options for preemptible instances.
- preferredMaintenance StringAction 
- The preferred maintenance action for an instance. The default is LIVE_MIGRATE, if live migration is supported.- LIVE_MIGRATE- Run maintenance using a live migration.
- REBOOT- Run maintenance using a reboot.
 
- shape String
- The shape of an instance. The shape determines the number of CPUs, amount of memory, and other resources allocated to the instance.
- shapeConfig Property Map
- The shape configuration requested for the instance.
- sourceDetails Property Map
InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfig, InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigArgs                  
- AreAll boolPlugins Disabled 
- Whether Oracle Cloud Agent can run all the available plugins. This includes the management and monitoring plugins.
- IsManagement boolDisabled 
- Whether Oracle Cloud Agent can run all the available management plugins. Default value is false (management plugins are enabled).
- IsMonitoring boolDisabled 
- Whether Oracle Cloud Agent can gather performance metrics and monitor the instance using the monitoring plugins. Default value is false (monitoring plugins are enabled).
- PluginsConfigs List<InstanceConfiguration Instance Details Option Launch Details Agent Config Plugins Config> 
- The configuration of plugins associated with this instance.
- AreAll boolPlugins Disabled 
- Whether Oracle Cloud Agent can run all the available plugins. This includes the management and monitoring plugins.
- IsManagement boolDisabled 
- Whether Oracle Cloud Agent can run all the available management plugins. Default value is false (management plugins are enabled).
- IsMonitoring boolDisabled 
- Whether Oracle Cloud Agent can gather performance metrics and monitor the instance using the monitoring plugins. Default value is false (monitoring plugins are enabled).
- PluginsConfigs []InstanceConfiguration Instance Details Option Launch Details Agent Config Plugins Config 
- The configuration of plugins associated with this instance.
- areAll BooleanPlugins Disabled 
- Whether Oracle Cloud Agent can run all the available plugins. This includes the management and monitoring plugins.
- isManagement BooleanDisabled 
- Whether Oracle Cloud Agent can run all the available management plugins. Default value is false (management plugins are enabled).
- isMonitoring BooleanDisabled 
- Whether Oracle Cloud Agent can gather performance metrics and monitor the instance using the monitoring plugins. Default value is false (monitoring plugins are enabled).
- pluginsConfigs List<InstanceConfiguration Instance Details Option Launch Details Agent Config Plugins Config> 
- The configuration of plugins associated with this instance.
- areAll booleanPlugins Disabled 
- Whether Oracle Cloud Agent can run all the available plugins. This includes the management and monitoring plugins.
- isManagement booleanDisabled 
- Whether Oracle Cloud Agent can run all the available management plugins. Default value is false (management plugins are enabled).
- isMonitoring booleanDisabled 
- Whether Oracle Cloud Agent can gather performance metrics and monitor the instance using the monitoring plugins. Default value is false (monitoring plugins are enabled).
- pluginsConfigs InstanceConfiguration Instance Details Option Launch Details Agent Config Plugins Config[] 
- The configuration of plugins associated with this instance.
- are_all_ boolplugins_ disabled 
- Whether Oracle Cloud Agent can run all the available plugins. This includes the management and monitoring plugins.
- is_management_ booldisabled 
- Whether Oracle Cloud Agent can run all the available management plugins. Default value is false (management plugins are enabled).
- is_monitoring_ booldisabled 
- Whether Oracle Cloud Agent can gather performance metrics and monitor the instance using the monitoring plugins. Default value is false (monitoring plugins are enabled).
- plugins_configs Sequence[core.Instance Configuration Instance Details Option Launch Details Agent Config Plugins Config] 
- The configuration of plugins associated with this instance.
- areAll BooleanPlugins Disabled 
- Whether Oracle Cloud Agent can run all the available plugins. This includes the management and monitoring plugins.
- isManagement BooleanDisabled 
- Whether Oracle Cloud Agent can run all the available management plugins. Default value is false (management plugins are enabled).
- isMonitoring BooleanDisabled 
- Whether Oracle Cloud Agent can gather performance metrics and monitor the instance using the monitoring plugins. Default value is false (monitoring plugins are enabled).
- pluginsConfigs List<Property Map>
- The configuration of plugins associated with this instance.
InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigPluginsConfig, InstanceConfigurationInstanceDetailsOptionLaunchDetailsAgentConfigPluginsConfigArgs                      
- DesiredState string
- Whether the plugin should be enabled or disabled.
- Name string
- The plugin name. To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent.
- DesiredState string
- Whether the plugin should be enabled or disabled.
- Name string
- The plugin name. To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent.
- desiredState String
- Whether the plugin should be enabled or disabled.
- name String
- The plugin name. To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent.
- desiredState string
- Whether the plugin should be enabled or disabled.
- name string
- The plugin name. To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent.
- desired_state str
- Whether the plugin should be enabled or disabled.
- name str
- The plugin name. To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent.
- desiredState String
- Whether the plugin should be enabled or disabled.
- name String
- The plugin name. To get a list of available plugins, use the ListInstanceagentAvailablePlugins operation in the Oracle Cloud Agent API. For more information about the available plugins, see Managing Plugins with Oracle Cloud Agent.
InstanceConfigurationInstanceDetailsOptionLaunchDetailsAvailabilityConfig, InstanceConfigurationInstanceDetailsOptionLaunchDetailsAvailabilityConfigArgs                  
- IsLive boolMigration Preferred 
- Whether to live migrate supported VM instances to a healthy physical VM host without disrupting running instances during infrastructure maintenance events. If null, Oracle chooses the best option for migrating the VM during infrastructure maintenance events.
- RecoveryAction string
- The lifecycle state for an instance when it is recovered after infrastructure maintenance.- RESTORE_INSTANCE- The instance is restored to the lifecycle state it was in before the maintenance event. If the instance was running, it is automatically rebooted. This is the default action when a value is not set.
- STOP_INSTANCE- The instance is recovered in the stopped state.
 
- IsLive boolMigration Preferred 
- Whether to live migrate supported VM instances to a healthy physical VM host without disrupting running instances during infrastructure maintenance events. If null, Oracle chooses the best option for migrating the VM during infrastructure maintenance events.
- RecoveryAction string
- The lifecycle state for an instance when it is recovered after infrastructure maintenance.- RESTORE_INSTANCE- The instance is restored to the lifecycle state it was in before the maintenance event. If the instance was running, it is automatically rebooted. This is the default action when a value is not set.
- STOP_INSTANCE- The instance is recovered in the stopped state.
 
- isLive BooleanMigration Preferred 
- Whether to live migrate supported VM instances to a healthy physical VM host without disrupting running instances during infrastructure maintenance events. If null, Oracle chooses the best option for migrating the VM during infrastructure maintenance events.
- recoveryAction String
- The lifecycle state for an instance when it is recovered after infrastructure maintenance.- RESTORE_INSTANCE- The instance is restored to the lifecycle state it was in before the maintenance event. If the instance was running, it is automatically rebooted. This is the default action when a value is not set.
- STOP_INSTANCE- The instance is recovered in the stopped state.
 
- isLive booleanMigration Preferred 
- Whether to live migrate supported VM instances to a healthy physical VM host without disrupting running instances during infrastructure maintenance events. If null, Oracle chooses the best option for migrating the VM during infrastructure maintenance events.
- recoveryAction string
- The lifecycle state for an instance when it is recovered after infrastructure maintenance.- RESTORE_INSTANCE- The instance is restored to the lifecycle state it was in before the maintenance event. If the instance was running, it is automatically rebooted. This is the default action when a value is not set.
- STOP_INSTANCE- The instance is recovered in the stopped state.
 
- is_live_ boolmigration_ preferred 
- Whether to live migrate supported VM instances to a healthy physical VM host without disrupting running instances during infrastructure maintenance events. If null, Oracle chooses the best option for migrating the VM during infrastructure maintenance events.
- recovery_action str
- The lifecycle state for an instance when it is recovered after infrastructure maintenance.- RESTORE_INSTANCE- The instance is restored to the lifecycle state it was in before the maintenance event. If the instance was running, it is automatically rebooted. This is the default action when a value is not set.
- STOP_INSTANCE- The instance is recovered in the stopped state.
 
- isLive BooleanMigration Preferred 
- Whether to live migrate supported VM instances to a healthy physical VM host without disrupting running instances during infrastructure maintenance events. If null, Oracle chooses the best option for migrating the VM during infrastructure maintenance events.
- recoveryAction String
- The lifecycle state for an instance when it is recovered after infrastructure maintenance.- RESTORE_INSTANCE- The instance is restored to the lifecycle state it was in before the maintenance event. If the instance was running, it is automatically rebooted. This is the default action when a value is not set.
- STOP_INSTANCE- The instance is recovered in the stopped state.
 
InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetails, InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsArgs                    
- AssignIpv6ip bool
- AssignPrivate boolDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- AssignPublic boolIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Dictionary<string, object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Dictionary<string, object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- HostnameLabel string
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- Ipv6addressIpv6subnet List<InstanceCidr Pair Details Configuration Instance Details Option Launch Details Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail> 
- NsgIds List<string>
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- PrivateIp string
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- SkipSource boolDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- SubnetId string
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- AssignIpv6ip bool
- AssignPrivate boolDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- AssignPublic boolIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- map[string]interface{}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- map[string]interface{}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- HostnameLabel string
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- Ipv6addressIpv6subnet []InstanceCidr Pair Details Configuration Instance Details Option Launch Details Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail 
- NsgIds []string
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- PrivateIp string
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- SkipSource boolDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- SubnetId string
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assignIpv6ip Boolean
- assignPrivate BooleanDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assignPublic BooleanIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Map<String,Object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<String,Object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostnameLabel String
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6addressIpv6subnet List<InstanceCidr Pair Details Configuration Instance Details Option Launch Details Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail> 
- nsgIds List<String>
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- privateIp String
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skipSource BooleanDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnetId String
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assignIpv6ip boolean
- assignPrivate booleanDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assignPublic booleanIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- {[key: string]: any}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- {[key: string]: any}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostnameLabel string
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6addressIpv6subnet InstanceCidr Pair Details Configuration Instance Details Option Launch Details Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail[] 
- nsgIds string[]
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- privateIp string
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skipSource booleanDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnetId string
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assign_ipv6ip bool
- assign_private_ booldns_ record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assign_public_ boolip 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Mapping[str, Any]
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- display_name str
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Mapping[str, Any]
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostname_label str
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6address_ipv6subnet_ Sequence[core.cidr_ pair_ details Instance Configuration Instance Details Option Launch Details Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail] 
- nsg_ids Sequence[str]
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- private_ip str
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skip_source_ booldest_ check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnet_id str
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assignIpv6ip Boolean
- assignPrivate BooleanDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assignPublic BooleanIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Map<Any>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<Any>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostnameLabel String
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6addressIpv6subnet List<Property Map>Cidr Pair Details 
- nsgIds List<String>
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- privateIp String
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skipSource BooleanDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnetId String
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetail, InstanceConfigurationInstanceDetailsOptionLaunchDetailsCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs                              
- Ipv6address string
- Ipv6subnetCidr string
- Ipv6address string
- Ipv6subnetCidr string
- ipv6address String
- ipv6subnetCidr String
- ipv6address string
- ipv6subnetCidr string
- ipv6address str
- ipv6subnet_cidr str
- ipv6address String
- ipv6subnetCidr String
InstanceConfigurationInstanceDetailsOptionLaunchDetailsInstanceOptions, InstanceConfigurationInstanceDetailsOptionLaunchDetailsInstanceOptionsArgs                  
- AreLegacy boolImds Endpoints Disabled 
- Whether to disable the legacy (/v1) instance metadata service endpoints. Customers who have migrated to /v2 should set this to true for added security. Default is false.
- AreLegacy boolImds Endpoints Disabled 
- Whether to disable the legacy (/v1) instance metadata service endpoints. Customers who have migrated to /v2 should set this to true for added security. Default is false.
- areLegacy BooleanImds Endpoints Disabled 
- Whether to disable the legacy (/v1) instance metadata service endpoints. Customers who have migrated to /v2 should set this to true for added security. Default is false.
- areLegacy booleanImds Endpoints Disabled 
- Whether to disable the legacy (/v1) instance metadata service endpoints. Customers who have migrated to /v2 should set this to true for added security. Default is false.
- are_legacy_ boolimds_ endpoints_ disabled 
- Whether to disable the legacy (/v1) instance metadata service endpoints. Customers who have migrated to /v2 should set this to true for added security. Default is false.
- areLegacy BooleanImds Endpoints Disabled 
- Whether to disable the legacy (/v1) instance metadata service endpoints. Customers who have migrated to /v2 should set this to true for added security. Default is false.
InstanceConfigurationInstanceDetailsOptionLaunchDetailsLaunchOptions, InstanceConfigurationInstanceDetailsOptionLaunchDetailsLaunchOptionsArgs                  
- BootVolume stringType 
- Emulation type for the boot volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- Firmware string
- Firmware used to boot VM. Select the option that matches your operating system.- BIOS- Boot VM using BIOS style firmware. This is compatible with both 32 bit and 64 bit operating systems that boot using MBR style bootloaders.
- UEFI_64- Boot VM using UEFI style firmware compatible with 64 bit operating systems. This is the default for platform images.
 
- IsConsistent boolVolume Naming Enabled 
- Whether to enable consistent volume naming feature. Defaults to false.
- IsPv boolEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- NetworkType string
- Emulation type for the physical network interface card (NIC).- E1000- Emulated Gigabit ethernet controller. Compatible with Linux e1000 network driver.
- VFIO- Direct attached Virtual Function network controller. This is the networking type when you launch an instance using hardware-assisted (SR-IOV) networking.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
 
- RemoteData stringVolume Type 
- Emulation type for volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- BootVolume stringType 
- Emulation type for the boot volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- Firmware string
- Firmware used to boot VM. Select the option that matches your operating system.- BIOS- Boot VM using BIOS style firmware. This is compatible with both 32 bit and 64 bit operating systems that boot using MBR style bootloaders.
- UEFI_64- Boot VM using UEFI style firmware compatible with 64 bit operating systems. This is the default for platform images.
 
- IsConsistent boolVolume Naming Enabled 
- Whether to enable consistent volume naming feature. Defaults to false.
- IsPv boolEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- NetworkType string
- Emulation type for the physical network interface card (NIC).- E1000- Emulated Gigabit ethernet controller. Compatible with Linux e1000 network driver.
- VFIO- Direct attached Virtual Function network controller. This is the networking type when you launch an instance using hardware-assisted (SR-IOV) networking.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
 
- RemoteData stringVolume Type 
- Emulation type for volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- bootVolume StringType 
- Emulation type for the boot volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- firmware String
- Firmware used to boot VM. Select the option that matches your operating system.- BIOS- Boot VM using BIOS style firmware. This is compatible with both 32 bit and 64 bit operating systems that boot using MBR style bootloaders.
- UEFI_64- Boot VM using UEFI style firmware compatible with 64 bit operating systems. This is the default for platform images.
 
- isConsistent BooleanVolume Naming Enabled 
- Whether to enable consistent volume naming feature. Defaults to false.
- isPv BooleanEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- networkType String
- Emulation type for the physical network interface card (NIC).- E1000- Emulated Gigabit ethernet controller. Compatible with Linux e1000 network driver.
- VFIO- Direct attached Virtual Function network controller. This is the networking type when you launch an instance using hardware-assisted (SR-IOV) networking.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
 
- remoteData StringVolume Type 
- Emulation type for volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- bootVolume stringType 
- Emulation type for the boot volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- firmware string
- Firmware used to boot VM. Select the option that matches your operating system.- BIOS- Boot VM using BIOS style firmware. This is compatible with both 32 bit and 64 bit operating systems that boot using MBR style bootloaders.
- UEFI_64- Boot VM using UEFI style firmware compatible with 64 bit operating systems. This is the default for platform images.
 
- isConsistent booleanVolume Naming Enabled 
- Whether to enable consistent volume naming feature. Defaults to false.
- isPv booleanEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- networkType string
- Emulation type for the physical network interface card (NIC).- E1000- Emulated Gigabit ethernet controller. Compatible with Linux e1000 network driver.
- VFIO- Direct attached Virtual Function network controller. This is the networking type when you launch an instance using hardware-assisted (SR-IOV) networking.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
 
- remoteData stringVolume Type 
- Emulation type for volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- boot_volume_ strtype 
- Emulation type for the boot volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- firmware str
- Firmware used to boot VM. Select the option that matches your operating system.- BIOS- Boot VM using BIOS style firmware. This is compatible with both 32 bit and 64 bit operating systems that boot using MBR style bootloaders.
- UEFI_64- Boot VM using UEFI style firmware compatible with 64 bit operating systems. This is the default for platform images.
 
- is_consistent_ boolvolume_ naming_ enabled 
- Whether to enable consistent volume naming feature. Defaults to false.
- is_pv_ boolencryption_ in_ transit_ enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- network_type str
- Emulation type for the physical network interface card (NIC).- E1000- Emulated Gigabit ethernet controller. Compatible with Linux e1000 network driver.
- VFIO- Direct attached Virtual Function network controller. This is the networking type when you launch an instance using hardware-assisted (SR-IOV) networking.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
 
- remote_data_ strvolume_ type 
- Emulation type for volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- bootVolume StringType 
- Emulation type for the boot volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
- firmware String
- Firmware used to boot VM. Select the option that matches your operating system.- BIOS- Boot VM using BIOS style firmware. This is compatible with both 32 bit and 64 bit operating systems that boot using MBR style bootloaders.
- UEFI_64- Boot VM using UEFI style firmware compatible with 64 bit operating systems. This is the default for platform images.
 
- isConsistent BooleanVolume Naming Enabled 
- Whether to enable consistent volume naming feature. Defaults to false.
- isPv BooleanEncryption In Transit Enabled 
- Deprecated. Instead use isPvEncryptionInTransitEnabledin InstanceConfigurationLaunchInstanceDetails.
- networkType String
- Emulation type for the physical network interface card (NIC).- E1000- Emulated Gigabit ethernet controller. Compatible with Linux e1000 network driver.
- VFIO- Direct attached Virtual Function network controller. This is the networking type when you launch an instance using hardware-assisted (SR-IOV) networking.
- PARAVIRTUALIZED- VM instances launch with paravirtualized devices using VirtIO drivers.
 
- remoteData StringVolume Type 
- Emulation type for volume.- ISCSI- ISCSI attached block storage device.
- SCSI- Emulated SCSI disk.
- IDE- Emulated IDE disk.
- VFIO- Direct attached Virtual Function storage. This is the default option for local data volumes on platform images.
- PARAVIRTUALIZED- Paravirtualized disk. This is the default for boot volumes and remote block storage volumes on platform images.
 
InstanceConfigurationInstanceDetailsOptionLaunchDetailsPlatformConfig, InstanceConfigurationInstanceDetailsOptionLaunchDetailsPlatformConfigArgs                  
- Type string
- The type of action to run when the instance is interrupted for eviction.
- AreVirtual boolInstructions Enabled 
- Whether virtualization instructions are available. For example, Secure Virtual Machine for AMD shapes or VT-x for Intel shapes.
- IsAccess boolControl Service Enabled 
- Whether the Access Control Service is enabled on the instance. When enabled, the platform can enforce PCIe device isolation, required for VFIO device pass-through.
- IsInput boolOutput Memory Management Unit Enabled 
- Whether the input-output memory management unit is enabled.
- IsMeasured boolBoot Enabled 
- Whether the Measured Boot feature is enabled on the instance.
- IsMemory boolEncryption Enabled 
- Whether the instance is a confidential instance. If this value is true, the instance is a confidential instance. The default value isfalse.
- IsSecure boolBoot Enabled 
- Whether Secure Boot is enabled on the instance.
- IsSymmetric boolMulti Threading Enabled 
- Whether symmetric multithreading is enabled on the instance. Symmetric multithreading is also called simultaneous multithreading (SMT) or Intel Hyper-Threading.
- IsTrusted boolPlatform Module Enabled 
- Whether the Trusted Platform Module (TPM) is enabled on the instance.
- NumaNodes stringPer Socket 
- The number of NUMA nodes per socket (NPS).
- PercentageOf intCores Enabled 
- The percentage of cores enabled. Value must be a multiple of 25%. If the requested percentage results in a fractional number of cores, the system rounds up the number of cores across processors and provisions an instance with a whole number of cores. - If the applications that you run on the instance use a core-based licensing model and need fewer cores than the full size of the shape, you can disable cores to reduce your licensing costs. The instance itself is billed for the full shape, regardless of whether all cores are enabled. 
- Type string
- The type of action to run when the instance is interrupted for eviction.
- AreVirtual boolInstructions Enabled 
- Whether virtualization instructions are available. For example, Secure Virtual Machine for AMD shapes or VT-x for Intel shapes.
- IsAccess boolControl Service Enabled 
- Whether the Access Control Service is enabled on the instance. When enabled, the platform can enforce PCIe device isolation, required for VFIO device pass-through.
- IsInput boolOutput Memory Management Unit Enabled 
- Whether the input-output memory management unit is enabled.
- IsMeasured boolBoot Enabled 
- Whether the Measured Boot feature is enabled on the instance.
- IsMemory boolEncryption Enabled 
- Whether the instance is a confidential instance. If this value is true, the instance is a confidential instance. The default value isfalse.
- IsSecure boolBoot Enabled 
- Whether Secure Boot is enabled on the instance.
- IsSymmetric boolMulti Threading Enabled 
- Whether symmetric multithreading is enabled on the instance. Symmetric multithreading is also called simultaneous multithreading (SMT) or Intel Hyper-Threading.
- IsTrusted boolPlatform Module Enabled 
- Whether the Trusted Platform Module (TPM) is enabled on the instance.
- NumaNodes stringPer Socket 
- The number of NUMA nodes per socket (NPS).
- PercentageOf intCores Enabled 
- The percentage of cores enabled. Value must be a multiple of 25%. If the requested percentage results in a fractional number of cores, the system rounds up the number of cores across processors and provisions an instance with a whole number of cores. - If the applications that you run on the instance use a core-based licensing model and need fewer cores than the full size of the shape, you can disable cores to reduce your licensing costs. The instance itself is billed for the full shape, regardless of whether all cores are enabled. 
- type String
- The type of action to run when the instance is interrupted for eviction.
- areVirtual BooleanInstructions Enabled 
- Whether virtualization instructions are available. For example, Secure Virtual Machine for AMD shapes or VT-x for Intel shapes.
- isAccess BooleanControl Service Enabled 
- Whether the Access Control Service is enabled on the instance. When enabled, the platform can enforce PCIe device isolation, required for VFIO device pass-through.
- isInput BooleanOutput Memory Management Unit Enabled 
- Whether the input-output memory management unit is enabled.
- isMeasured BooleanBoot Enabled 
- Whether the Measured Boot feature is enabled on the instance.
- isMemory BooleanEncryption Enabled 
- Whether the instance is a confidential instance. If this value is true, the instance is a confidential instance. The default value isfalse.
- isSecure BooleanBoot Enabled 
- Whether Secure Boot is enabled on the instance.
- isSymmetric BooleanMulti Threading Enabled 
- Whether symmetric multithreading is enabled on the instance. Symmetric multithreading is also called simultaneous multithreading (SMT) or Intel Hyper-Threading.
- isTrusted BooleanPlatform Module Enabled 
- Whether the Trusted Platform Module (TPM) is enabled on the instance.
- numaNodes StringPer Socket 
- The number of NUMA nodes per socket (NPS).
- percentageOf IntegerCores Enabled 
- The percentage of cores enabled. Value must be a multiple of 25%. If the requested percentage results in a fractional number of cores, the system rounds up the number of cores across processors and provisions an instance with a whole number of cores. - If the applications that you run on the instance use a core-based licensing model and need fewer cores than the full size of the shape, you can disable cores to reduce your licensing costs. The instance itself is billed for the full shape, regardless of whether all cores are enabled. 
- type string
- The type of action to run when the instance is interrupted for eviction.
- areVirtual booleanInstructions Enabled 
- Whether virtualization instructions are available. For example, Secure Virtual Machine for AMD shapes or VT-x for Intel shapes.
- isAccess booleanControl Service Enabled 
- Whether the Access Control Service is enabled on the instance. When enabled, the platform can enforce PCIe device isolation, required for VFIO device pass-through.
- isInput booleanOutput Memory Management Unit Enabled 
- Whether the input-output memory management unit is enabled.
- isMeasured booleanBoot Enabled 
- Whether the Measured Boot feature is enabled on the instance.
- isMemory booleanEncryption Enabled 
- Whether the instance is a confidential instance. If this value is true, the instance is a confidential instance. The default value isfalse.
- isSecure booleanBoot Enabled 
- Whether Secure Boot is enabled on the instance.
- isSymmetric booleanMulti Threading Enabled 
- Whether symmetric multithreading is enabled on the instance. Symmetric multithreading is also called simultaneous multithreading (SMT) or Intel Hyper-Threading.
- isTrusted booleanPlatform Module Enabled 
- Whether the Trusted Platform Module (TPM) is enabled on the instance.
- numaNodes stringPer Socket 
- The number of NUMA nodes per socket (NPS).
- percentageOf numberCores Enabled 
- The percentage of cores enabled. Value must be a multiple of 25%. If the requested percentage results in a fractional number of cores, the system rounds up the number of cores across processors and provisions an instance with a whole number of cores. - If the applications that you run on the instance use a core-based licensing model and need fewer cores than the full size of the shape, you can disable cores to reduce your licensing costs. The instance itself is billed for the full shape, regardless of whether all cores are enabled. 
- type str
- The type of action to run when the instance is interrupted for eviction.
- are_virtual_ boolinstructions_ enabled 
- Whether virtualization instructions are available. For example, Secure Virtual Machine for AMD shapes or VT-x for Intel shapes.
- is_access_ boolcontrol_ service_ enabled 
- Whether the Access Control Service is enabled on the instance. When enabled, the platform can enforce PCIe device isolation, required for VFIO device pass-through.
- is_input_ booloutput_ memory_ management_ unit_ enabled 
- Whether the input-output memory management unit is enabled.
- is_measured_ boolboot_ enabled 
- Whether the Measured Boot feature is enabled on the instance.
- is_memory_ boolencryption_ enabled 
- Whether the instance is a confidential instance. If this value is true, the instance is a confidential instance. The default value isfalse.
- is_secure_ boolboot_ enabled 
- Whether Secure Boot is enabled on the instance.
- is_symmetric_ boolmulti_ threading_ enabled 
- Whether symmetric multithreading is enabled on the instance. Symmetric multithreading is also called simultaneous multithreading (SMT) or Intel Hyper-Threading.
- is_trusted_ boolplatform_ module_ enabled 
- Whether the Trusted Platform Module (TPM) is enabled on the instance.
- numa_nodes_ strper_ socket 
- The number of NUMA nodes per socket (NPS).
- percentage_of_ intcores_ enabled 
- The percentage of cores enabled. Value must be a multiple of 25%. If the requested percentage results in a fractional number of cores, the system rounds up the number of cores across processors and provisions an instance with a whole number of cores. - If the applications that you run on the instance use a core-based licensing model and need fewer cores than the full size of the shape, you can disable cores to reduce your licensing costs. The instance itself is billed for the full shape, regardless of whether all cores are enabled. 
- type String
- The type of action to run when the instance is interrupted for eviction.
- areVirtual BooleanInstructions Enabled 
- Whether virtualization instructions are available. For example, Secure Virtual Machine for AMD shapes or VT-x for Intel shapes.
- isAccess BooleanControl Service Enabled 
- Whether the Access Control Service is enabled on the instance. When enabled, the platform can enforce PCIe device isolation, required for VFIO device pass-through.
- isInput BooleanOutput Memory Management Unit Enabled 
- Whether the input-output memory management unit is enabled.
- isMeasured BooleanBoot Enabled 
- Whether the Measured Boot feature is enabled on the instance.
- isMemory BooleanEncryption Enabled 
- Whether the instance is a confidential instance. If this value is true, the instance is a confidential instance. The default value isfalse.
- isSecure BooleanBoot Enabled 
- Whether Secure Boot is enabled on the instance.
- isSymmetric BooleanMulti Threading Enabled 
- Whether symmetric multithreading is enabled on the instance. Symmetric multithreading is also called simultaneous multithreading (SMT) or Intel Hyper-Threading.
- isTrusted BooleanPlatform Module Enabled 
- Whether the Trusted Platform Module (TPM) is enabled on the instance.
- numaNodes StringPer Socket 
- The number of NUMA nodes per socket (NPS).
- percentageOf NumberCores Enabled 
- The percentage of cores enabled. Value must be a multiple of 25%. If the requested percentage results in a fractional number of cores, the system rounds up the number of cores across processors and provisions an instance with a whole number of cores. - If the applications that you run on the instance use a core-based licensing model and need fewer cores than the full size of the shape, you can disable cores to reduce your licensing costs. The instance itself is billed for the full shape, regardless of whether all cores are enabled. 
InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfig, InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigArgs                    
- PreemptionAction InstanceConfiguration Instance Details Option Launch Details Preemptible Instance Config Preemption Action 
- The action to run when the preemptible instance is interrupted for eviction.
- PreemptionAction InstanceConfiguration Instance Details Option Launch Details Preemptible Instance Config Preemption Action 
- The action to run when the preemptible instance is interrupted for eviction.
- preemptionAction InstanceConfiguration Instance Details Option Launch Details Preemptible Instance Config Preemption Action 
- The action to run when the preemptible instance is interrupted for eviction.
- preemptionAction InstanceConfiguration Instance Details Option Launch Details Preemptible Instance Config Preemption Action 
- The action to run when the preemptible instance is interrupted for eviction.
- preemption_action core.Instance Configuration Instance Details Option Launch Details Preemptible Instance Config Preemption Action 
- The action to run when the preemptible instance is interrupted for eviction.
- preemptionAction Property Map
- The action to run when the preemptible instance is interrupted for eviction.
InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigPreemptionAction, InstanceConfigurationInstanceDetailsOptionLaunchDetailsPreemptibleInstanceConfigPreemptionActionArgs                        
- Type string
- The type of action to run when the instance is interrupted for eviction.
- PreserveBoot boolVolume 
- Whether to preserve the boot volume that was used to launch the preemptible instance when the instance is terminated. Defaults to false if not specified.
- Type string
- The type of action to run when the instance is interrupted for eviction.
- PreserveBoot boolVolume 
- Whether to preserve the boot volume that was used to launch the preemptible instance when the instance is terminated. Defaults to false if not specified.
- type String
- The type of action to run when the instance is interrupted for eviction.
- preserveBoot BooleanVolume 
- Whether to preserve the boot volume that was used to launch the preemptible instance when the instance is terminated. Defaults to false if not specified.
- type string
- The type of action to run when the instance is interrupted for eviction.
- preserveBoot booleanVolume 
- Whether to preserve the boot volume that was used to launch the preemptible instance when the instance is terminated. Defaults to false if not specified.
- type str
- The type of action to run when the instance is interrupted for eviction.
- preserve_boot_ boolvolume 
- Whether to preserve the boot volume that was used to launch the preemptible instance when the instance is terminated. Defaults to false if not specified.
- type String
- The type of action to run when the instance is interrupted for eviction.
- preserveBoot BooleanVolume 
- Whether to preserve the boot volume that was used to launch the preemptible instance when the instance is terminated. Defaults to false if not specified.
InstanceConfigurationInstanceDetailsOptionLaunchDetailsShapeConfig, InstanceConfigurationInstanceDetailsOptionLaunchDetailsShapeConfigArgs                  
- BaselineOcpu stringUtilization 
- The baseline OCPU utilization for a subcore burstable VM instance. Leave this attribute blank for a non-burstable instance, or explicitly specify non-burstable with BASELINE_1_1.
- MemoryIn doubleGbs 
- The total amount of memory available to the instance, in gigabytes.
- Nvmes int
- The number of NVMe drives to be used for storage. A single drive has 6.8 TB available.
- Ocpus double
- The total number of OCPUs available to the instance.
- Vcpus int
- The total number of VCPUs available to the instance. This can be used instead of OCPUs, in which case the actual number of OCPUs will be calculated based on this value and the actual hardware. This must be a multiple of 2.
- BaselineOcpu stringUtilization 
- The baseline OCPU utilization for a subcore burstable VM instance. Leave this attribute blank for a non-burstable instance, or explicitly specify non-burstable with BASELINE_1_1.
- MemoryIn float64Gbs 
- The total amount of memory available to the instance, in gigabytes.
- Nvmes int
- The number of NVMe drives to be used for storage. A single drive has 6.8 TB available.
- Ocpus float64
- The total number of OCPUs available to the instance.
- Vcpus int
- The total number of VCPUs available to the instance. This can be used instead of OCPUs, in which case the actual number of OCPUs will be calculated based on this value and the actual hardware. This must be a multiple of 2.
- baselineOcpu StringUtilization 
- The baseline OCPU utilization for a subcore burstable VM instance. Leave this attribute blank for a non-burstable instance, or explicitly specify non-burstable with BASELINE_1_1.
- memoryIn DoubleGbs 
- The total amount of memory available to the instance, in gigabytes.
- nvmes Integer
- The number of NVMe drives to be used for storage. A single drive has 6.8 TB available.
- ocpus Double
- The total number of OCPUs available to the instance.
- vcpus Integer
- The total number of VCPUs available to the instance. This can be used instead of OCPUs, in which case the actual number of OCPUs will be calculated based on this value and the actual hardware. This must be a multiple of 2.
- baselineOcpu stringUtilization 
- The baseline OCPU utilization for a subcore burstable VM instance. Leave this attribute blank for a non-burstable instance, or explicitly specify non-burstable with BASELINE_1_1.
- memoryIn numberGbs 
- The total amount of memory available to the instance, in gigabytes.
- nvmes number
- The number of NVMe drives to be used for storage. A single drive has 6.8 TB available.
- ocpus number
- The total number of OCPUs available to the instance.
- vcpus number
- The total number of VCPUs available to the instance. This can be used instead of OCPUs, in which case the actual number of OCPUs will be calculated based on this value and the actual hardware. This must be a multiple of 2.
- baseline_ocpu_ strutilization 
- The baseline OCPU utilization for a subcore burstable VM instance. Leave this attribute blank for a non-burstable instance, or explicitly specify non-burstable with BASELINE_1_1.
- memory_in_ floatgbs 
- The total amount of memory available to the instance, in gigabytes.
- nvmes int
- The number of NVMe drives to be used for storage. A single drive has 6.8 TB available.
- ocpus float
- The total number of OCPUs available to the instance.
- vcpus int
- The total number of VCPUs available to the instance. This can be used instead of OCPUs, in which case the actual number of OCPUs will be calculated based on this value and the actual hardware. This must be a multiple of 2.
- baselineOcpu StringUtilization 
- The baseline OCPU utilization for a subcore burstable VM instance. Leave this attribute blank for a non-burstable instance, or explicitly specify non-burstable with BASELINE_1_1.
- memoryIn NumberGbs 
- The total amount of memory available to the instance, in gigabytes.
- nvmes Number
- The number of NVMe drives to be used for storage. A single drive has 6.8 TB available.
- ocpus Number
- The total number of OCPUs available to the instance.
- vcpus Number
- The total number of VCPUs available to the instance. This can be used instead of OCPUs, in which case the actual number of OCPUs will be calculated based on this value and the actual hardware. This must be a multiple of 2.
InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetails, InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsArgs                  
- SourceType string
- The source type for the instance. Use imagewhen specifying the image OCID. UsebootVolumewhen specifying the boot volume OCID.
- BootVolume stringId 
- The OCID of the boot volume used to boot the instance.
- BootVolume stringSize In Gbs 
- The size of the boot volume in GBs. The minimum value is 50 GB and the maximum value is 32,768 GB (32 TB).
- BootVolume stringVpus Per Gb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- ImageId string
- The OCID of the image used to boot the instance.
- InstanceSource InstanceImage Filter Details Configuration Instance Details Option Launch Details Source Details Instance Source Image Filter Details 
- These are the criteria for selecting an image. This is required if imageId is not specified.
- KmsKey stringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- SourceType string
- The source type for the instance. Use imagewhen specifying the image OCID. UsebootVolumewhen specifying the boot volume OCID.
- BootVolume stringId 
- The OCID of the boot volume used to boot the instance.
- BootVolume stringSize In Gbs 
- The size of the boot volume in GBs. The minimum value is 50 GB and the maximum value is 32,768 GB (32 TB).
- BootVolume stringVpus Per Gb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- ImageId string
- The OCID of the image used to boot the instance.
- InstanceSource InstanceImage Filter Details Configuration Instance Details Option Launch Details Source Details Instance Source Image Filter Details 
- These are the criteria for selecting an image. This is required if imageId is not specified.
- KmsKey stringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- sourceType String
- The source type for the instance. Use imagewhen specifying the image OCID. UsebootVolumewhen specifying the boot volume OCID.
- bootVolume StringId 
- The OCID of the boot volume used to boot the instance.
- bootVolume StringSize In Gbs 
- The size of the boot volume in GBs. The minimum value is 50 GB and the maximum value is 32,768 GB (32 TB).
- bootVolume StringVpus Per Gb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- imageId String
- The OCID of the image used to boot the instance.
- instanceSource InstanceImage Filter Details Configuration Instance Details Option Launch Details Source Details Instance Source Image Filter Details 
- These are the criteria for selecting an image. This is required if imageId is not specified.
- kmsKey StringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- sourceType string
- The source type for the instance. Use imagewhen specifying the image OCID. UsebootVolumewhen specifying the boot volume OCID.
- bootVolume stringId 
- The OCID of the boot volume used to boot the instance.
- bootVolume stringSize In Gbs 
- The size of the boot volume in GBs. The minimum value is 50 GB and the maximum value is 32,768 GB (32 TB).
- bootVolume stringVpus Per Gb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- imageId string
- The OCID of the image used to boot the instance.
- instanceSource InstanceImage Filter Details Configuration Instance Details Option Launch Details Source Details Instance Source Image Filter Details 
- These are the criteria for selecting an image. This is required if imageId is not specified.
- kmsKey stringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- source_type str
- The source type for the instance. Use imagewhen specifying the image OCID. UsebootVolumewhen specifying the boot volume OCID.
- boot_volume_ strid 
- The OCID of the boot volume used to boot the instance.
- boot_volume_ strsize_ in_ gbs 
- The size of the boot volume in GBs. The minimum value is 50 GB and the maximum value is 32,768 GB (32 TB).
- boot_volume_ strvpus_ per_ gb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- image_id str
- The OCID of the image used to boot the instance.
- instance_source_ core.image_ filter_ details Instance Configuration Instance Details Option Launch Details Source Details Instance Source Image Filter Details 
- These are the criteria for selecting an image. This is required if imageId is not specified.
- kms_key_ strid 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
- sourceType String
- The source type for the instance. Use imagewhen specifying the image OCID. UsebootVolumewhen specifying the boot volume OCID.
- bootVolume StringId 
- The OCID of the boot volume used to boot the instance.
- bootVolume StringSize In Gbs 
- The size of the boot volume in GBs. The minimum value is 50 GB and the maximum value is 32,768 GB (32 TB).
- bootVolume StringVpus Per Gb 
- The number of volume performance units (VPUs) that will be applied to this volume per GB, representing the Block Volume service's elastic performance options. See Block Volume Performance Levels for more information.
- imageId String
- The OCID of the image used to boot the instance.
- instanceSource Property MapImage Filter Details 
- These are the criteria for selecting an image. This is required if imageId is not specified.
- kmsKey StringId 
- The OCID of the Vault service key to assign as the master encryption key for the volume.
InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsInstanceSourceImageFilterDetails, InstanceConfigurationInstanceDetailsOptionLaunchDetailsSourceDetailsInstanceSourceImageFilterDetailsArgs                            
- CompartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- Dictionary<string, object>
- Filter based on these defined tags. Each key is predefined and scoped to a namespace. For more information, see Resource Tags.
- OperatingSystem string
- The image's operating system. Example: Oracle Linux
- OperatingSystem stringVersion 
- The image's operating system version. Example: 7.2
- CompartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- map[string]interface{}
- Filter based on these defined tags. Each key is predefined and scoped to a namespace. For more information, see Resource Tags.
- OperatingSystem string
- The image's operating system. Example: Oracle Linux
- OperatingSystem stringVersion 
- The image's operating system version. Example: 7.2
- compartmentId String
- (Updatable) The OCID of the compartment containing the instance configuration.
- Map<String,Object>
- Filter based on these defined tags. Each key is predefined and scoped to a namespace. For more information, see Resource Tags.
- operatingSystem String
- The image's operating system. Example: Oracle Linux
- operatingSystem StringVersion 
- The image's operating system version. Example: 7.2
- compartmentId string
- (Updatable) The OCID of the compartment containing the instance configuration.
- {[key: string]: any}
- Filter based on these defined tags. Each key is predefined and scoped to a namespace. For more information, see Resource Tags.
- operatingSystem string
- The image's operating system. Example: Oracle Linux
- operatingSystem stringVersion 
- The image's operating system version. Example: 7.2
- compartment_id str
- (Updatable) The OCID of the compartment containing the instance configuration.
- Mapping[str, Any]
- Filter based on these defined tags. Each key is predefined and scoped to a namespace. For more information, see Resource Tags.
- operating_system str
- The image's operating system. Example: Oracle Linux
- operating_system_ strversion 
- The image's operating system version. Example: 7.2
- compartmentId String
- (Updatable) The OCID of the compartment containing the instance configuration.
- Map<Any>
- Filter based on these defined tags. Each key is predefined and scoped to a namespace. For more information, see Resource Tags.
- operatingSystem String
- The image's operating system. Example: Oracle Linux
- operatingSystem StringVersion 
- The image's operating system version. Example: 7.2
InstanceConfigurationInstanceDetailsOptionSecondaryVnic, InstanceConfigurationInstanceDetailsOptionSecondaryVnicArgs              
- CreateVnic InstanceDetails Configuration Instance Details Option Secondary Vnic Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- NicIndex int
- Which physical network interface card (NIC) the VNIC will use. Defaults to 0. Certain bare metal instance shapes have two active physical NICs (0 and 1). If you add a secondary VNIC to one of these instances, you can specify which NIC the VNIC will use. For more information, see Virtual Network Interface Cards (VNICs).
- CreateVnic InstanceDetails Configuration Instance Details Option Secondary Vnic Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- NicIndex int
- Which physical network interface card (NIC) the VNIC will use. Defaults to 0. Certain bare metal instance shapes have two active physical NICs (0 and 1). If you add a secondary VNIC to one of these instances, you can specify which NIC the VNIC will use. For more information, see Virtual Network Interface Cards (VNICs).
- createVnic InstanceDetails Configuration Instance Details Option Secondary Vnic Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- nicIndex Integer
- Which physical network interface card (NIC) the VNIC will use. Defaults to 0. Certain bare metal instance shapes have two active physical NICs (0 and 1). If you add a secondary VNIC to one of these instances, you can specify which NIC the VNIC will use. For more information, see Virtual Network Interface Cards (VNICs).
- createVnic InstanceDetails Configuration Instance Details Option Secondary Vnic Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- displayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- nicIndex number
- Which physical network interface card (NIC) the VNIC will use. Defaults to 0. Certain bare metal instance shapes have two active physical NICs (0 and 1). If you add a secondary VNIC to one of these instances, you can specify which NIC the VNIC will use. For more information, see Virtual Network Interface Cards (VNICs).
- create_vnic_ core.details Instance Configuration Instance Details Option Secondary Vnic Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- display_name str
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- nic_index int
- Which physical network interface card (NIC) the VNIC will use. Defaults to 0. Certain bare metal instance shapes have two active physical NICs (0 and 1). If you add a secondary VNIC to one of these instances, you can specify which NIC the VNIC will use. For more information, see Virtual Network Interface Cards (VNICs).
- createVnic Property MapDetails 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- nicIndex Number
- Which physical network interface card (NIC) the VNIC will use. Defaults to 0. Certain bare metal instance shapes have two active physical NICs (0 and 1). If you add a secondary VNIC to one of these instances, you can specify which NIC the VNIC will use. For more information, see Virtual Network Interface Cards (VNICs).
InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetails, InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsArgs                    
- AssignIpv6ip bool
- AssignPrivate boolDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- AssignPublic boolIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Dictionary<string, object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Dictionary<string, object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- HostnameLabel string
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- Ipv6addressIpv6subnet List<InstanceCidr Pair Details Configuration Instance Details Option Secondary Vnic Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail> 
- NsgIds List<string>
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- PrivateIp string
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- SkipSource boolDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- SubnetId string
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- AssignIpv6ip bool
- AssignPrivate boolDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- AssignPublic boolIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- map[string]interface{}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- map[string]interface{}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- HostnameLabel string
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- Ipv6addressIpv6subnet []InstanceCidr Pair Details Configuration Instance Details Option Secondary Vnic Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail 
- NsgIds []string
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- PrivateIp string
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- SkipSource boolDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- SubnetId string
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assignIpv6ip Boolean
- assignPrivate BooleanDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assignPublic BooleanIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Map<String,Object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<String,Object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostnameLabel String
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6addressIpv6subnet List<InstanceCidr Pair Details Configuration Instance Details Option Secondary Vnic Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail> 
- nsgIds List<String>
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- privateIp String
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skipSource BooleanDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnetId String
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assignIpv6ip boolean
- assignPrivate booleanDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assignPublic booleanIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- {[key: string]: any}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- {[key: string]: any}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostnameLabel string
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6addressIpv6subnet InstanceCidr Pair Details Configuration Instance Details Option Secondary Vnic Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail[] 
- nsgIds string[]
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- privateIp string
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skipSource booleanDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnetId string
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assign_ipv6ip bool
- assign_private_ booldns_ record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assign_public_ boolip 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Mapping[str, Any]
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- display_name str
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Mapping[str, Any]
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostname_label str
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6address_ipv6subnet_ Sequence[core.cidr_ pair_ details Instance Configuration Instance Details Option Secondary Vnic Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail] 
- nsg_ids Sequence[str]
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- private_ip str
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skip_source_ booldest_ check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnet_id str
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assignIpv6ip Boolean
- assignPrivate BooleanDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assignPublic BooleanIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Map<Any>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<Any>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostnameLabel String
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6addressIpv6subnet List<Property Map>Cidr Pair Details 
- nsgIds List<String>
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- privateIp String
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skipSource BooleanDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnetId String
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetail, InstanceConfigurationInstanceDetailsOptionSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs                              
- Ipv6address string
- Ipv6subnetCidr string
- Ipv6address string
- Ipv6subnetCidr string
- ipv6address String
- ipv6subnetCidr String
- ipv6address string
- ipv6subnetCidr string
- ipv6address str
- ipv6subnet_cidr str
- ipv6address String
- ipv6subnetCidr String
InstanceConfigurationInstanceDetailsSecondaryVnic, InstanceConfigurationInstanceDetailsSecondaryVnicArgs            
- CreateVnic InstanceDetails Configuration Instance Details Secondary Vnic Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- NicIndex int
- Which physical network interface card (NIC) the VNIC will use. Defaults to 0. Certain bare metal instance shapes have two active physical NICs (0 and 1). If you add a secondary VNIC to one of these instances, you can specify which NIC the VNIC will use. For more information, see Virtual Network Interface Cards (VNICs).
- CreateVnic InstanceDetails Configuration Instance Details Secondary Vnic Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- NicIndex int
- Which physical network interface card (NIC) the VNIC will use. Defaults to 0. Certain bare metal instance shapes have two active physical NICs (0 and 1). If you add a secondary VNIC to one of these instances, you can specify which NIC the VNIC will use. For more information, see Virtual Network Interface Cards (VNICs).
- createVnic InstanceDetails Configuration Instance Details Secondary Vnic Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- nicIndex Integer
- Which physical network interface card (NIC) the VNIC will use. Defaults to 0. Certain bare metal instance shapes have two active physical NICs (0 and 1). If you add a secondary VNIC to one of these instances, you can specify which NIC the VNIC will use. For more information, see Virtual Network Interface Cards (VNICs).
- createVnic InstanceDetails Configuration Instance Details Secondary Vnic Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- displayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- nicIndex number
- Which physical network interface card (NIC) the VNIC will use. Defaults to 0. Certain bare metal instance shapes have two active physical NICs (0 and 1). If you add a secondary VNIC to one of these instances, you can specify which NIC the VNIC will use. For more information, see Virtual Network Interface Cards (VNICs).
- create_vnic_ core.details Instance Configuration Instance Details Secondary Vnic Create Vnic Details 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- display_name str
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- nic_index int
- Which physical network interface card (NIC) the VNIC will use. Defaults to 0. Certain bare metal instance shapes have two active physical NICs (0 and 1). If you add a secondary VNIC to one of these instances, you can specify which NIC the VNIC will use. For more information, see Virtual Network Interface Cards (VNICs).
- createVnic Property MapDetails 
- Contains the properties of the VNIC for an instance configuration. See CreateVnicDetails and Instance Configurations for more information.
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- nicIndex Number
- Which physical network interface card (NIC) the VNIC will use. Defaults to 0. Certain bare metal instance shapes have two active physical NICs (0 and 1). If you add a secondary VNIC to one of these instances, you can specify which NIC the VNIC will use. For more information, see Virtual Network Interface Cards (VNICs).
InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetails, InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsArgs                  
- AssignIpv6ip bool
- AssignPrivate boolDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- AssignPublic boolIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Dictionary<string, object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Dictionary<string, object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- HostnameLabel string
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- Ipv6addressIpv6subnet List<InstanceCidr Pair Details Configuration Instance Details Secondary Vnic Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail> 
- NsgIds List<string>
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- PrivateIp string
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- SkipSource boolDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- SubnetId string
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- AssignIpv6ip bool
- AssignPrivate boolDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- AssignPublic boolIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- map[string]interface{}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- DisplayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- map[string]interface{}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- HostnameLabel string
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- Ipv6addressIpv6subnet []InstanceCidr Pair Details Configuration Instance Details Secondary Vnic Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail 
- NsgIds []string
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- PrivateIp string
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- SkipSource boolDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- SubnetId string
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assignIpv6ip Boolean
- assignPrivate BooleanDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assignPublic BooleanIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Map<String,Object>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<String,Object>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostnameLabel String
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6addressIpv6subnet List<InstanceCidr Pair Details Configuration Instance Details Secondary Vnic Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail> 
- nsgIds List<String>
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- privateIp String
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skipSource BooleanDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnetId String
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assignIpv6ip boolean
- assignPrivate booleanDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assignPublic booleanIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- {[key: string]: any}
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName string
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- {[key: string]: any}
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostnameLabel string
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6addressIpv6subnet InstanceCidr Pair Details Configuration Instance Details Secondary Vnic Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail[] 
- nsgIds string[]
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- privateIp string
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skipSource booleanDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnetId string
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assign_ipv6ip bool
- assign_private_ booldns_ record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assign_public_ boolip 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Mapping[str, Any]
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- display_name str
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Mapping[str, Any]
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostname_label str
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6address_ipv6subnet_ Sequence[core.cidr_ pair_ details Instance Configuration Instance Details Secondary Vnic Create Vnic Details Ipv6address Ipv6subnet Cidr Pair Detail] 
- nsg_ids Sequence[str]
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- private_ip str
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skip_source_ booldest_ check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnet_id str
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
- assignIpv6ip Boolean
- assignPrivate BooleanDns Record 
- Whether the VNIC should be assigned a private DNS record. Defaults to true. See the assignPrivateDnsRecordattribute of CreateVnicDetails for more information.
- assignPublic BooleanIp 
- Whether the VNIC should be assigned a public IP address. See the assignPublicIpattribute of CreateVnicDetails for more information.
- Map<Any>
- (Updatable) Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- displayName String
- (Updatable) A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.
- Map<Any>
- (Updatable) Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- hostnameLabel String
- The hostname for the VNIC's primary private IP. See the hostnameLabelattribute of CreateVnicDetails for more information.
- ipv6addressIpv6subnet List<Property Map>Cidr Pair Details 
- nsgIds List<String>
- A list of the OCIDs of the network security groups (NSGs) to add the VNIC to. For more information about NSGs, see NetworkSecurityGroup.
- privateIp String
- A private IP address of your choice to assign to the VNIC. See the privateIpattribute of CreateVnicDetails for more information.
- skipSource BooleanDest Check 
- Whether the source/destination check is disabled on the VNIC. See the skipSourceDestCheckattribute of CreateVnicDetails for more information.
- subnetId String
- The OCID of the subnet to create the VNIC in. See the subnetIdattribute of CreateVnicDetails for more information.
InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetail, InstanceConfigurationInstanceDetailsSecondaryVnicCreateVnicDetailsIpv6addressIpv6subnetCidrPairDetailArgs                            
- Ipv6address string
- Ipv6subnetCidr string
- Ipv6address string
- Ipv6subnetCidr string
- ipv6address String
- ipv6subnetCidr String
- ipv6address string
- ipv6subnetCidr string
- ipv6address str
- ipv6subnet_cidr str
- ipv6address String
- ipv6subnetCidr String
Import
InstanceConfigurations can be imported using the id, e.g.
$ pulumi import oci:Core/instanceConfiguration:InstanceConfiguration test_instance_configuration "id"
To learn more about importing existing cloud resources, see Importing resources.
Package Details
- Repository
- oci pulumi/pulumi-oci
- License
- Apache-2.0
- Notes
- This Pulumi package is based on the ociTerraform Provider.