com.pulumi.gcp.tpu.kotlin.V2Vm.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pulumi-gcp-kotlin Show documentation
Show all versions of pulumi-gcp-kotlin Show documentation
Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.
@file:Suppress("NAME_SHADOWING", "DEPRECATION")
package com.pulumi.gcp.tpu.kotlin
import com.pulumi.core.Output
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmAcceleratorConfig
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmDataDisk
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmNetworkConfig
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmNetworkEndpoint
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmSchedulingConfig
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmServiceAccount
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmShieldedInstanceConfig
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmSymptom
import com.pulumi.kotlin.KotlinCustomResource
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.ResourceMapper
import com.pulumi.kotlin.options.CustomResourceOptions
import com.pulumi.kotlin.options.CustomResourceOptionsBuilder
import com.pulumi.resources.Resource
import kotlin.Boolean
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
import kotlin.collections.Map
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmAcceleratorConfig.Companion.toKotlin as v2VmAcceleratorConfigToKotlin
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmDataDisk.Companion.toKotlin as v2VmDataDiskToKotlin
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmNetworkConfig.Companion.toKotlin as v2VmNetworkConfigToKotlin
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmNetworkEndpoint.Companion.toKotlin as v2VmNetworkEndpointToKotlin
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmSchedulingConfig.Companion.toKotlin as v2VmSchedulingConfigToKotlin
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmServiceAccount.Companion.toKotlin as v2VmServiceAccountToKotlin
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmShieldedInstanceConfig.Companion.toKotlin as v2VmShieldedInstanceConfigToKotlin
import com.pulumi.gcp.tpu.kotlin.outputs.V2VmSymptom.Companion.toKotlin as v2VmSymptomToKotlin
/**
* Builder for [V2Vm].
*/
@PulumiTagMarker
public class V2VmResourceBuilder internal constructor() {
public var name: String? = null
public var args: V2VmArgs = V2VmArgs()
public var opts: CustomResourceOptions = CustomResourceOptions()
/**
* @param name The _unique_ name of the resulting resource.
*/
public fun name(`value`: String) {
this.name = value
}
/**
* @param block The arguments to use to populate this resource's properties.
*/
public suspend fun args(block: suspend V2VmArgsBuilder.() -> Unit) {
val builder = V2VmArgsBuilder()
block(builder)
this.args = builder.build()
}
/**
* @param block A bag of options that control this resource's behavior.
*/
public suspend fun opts(block: suspend CustomResourceOptionsBuilder.() -> Unit) {
this.opts = com.pulumi.kotlin.options.CustomResourceOptions.opts(block)
}
internal fun build(): V2Vm {
val builtJavaResource = com.pulumi.gcp.tpu.V2Vm(
this.name,
this.args.toJava(),
this.opts.toJava(),
)
return V2Vm(builtJavaResource)
}
}
/**
* ## Example Usage
* ### Tpu V2 Vm Basic
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as gcp from "@pulumi/gcp";
* const available = gcp.tpu.getV2RuntimeVersions({});
* const tpu = new gcp.tpu.V2Vm("tpu", {
* name: "test-tpu",
* zone: "us-central1-c",
* runtimeVersion: "tpu-vm-tf-2.13.0",
* });
* ```
* ```python
* import pulumi
* import pulumi_gcp as gcp
* available = gcp.tpu.get_v2_runtime_versions()
* tpu = gcp.tpu.V2Vm("tpu",
* name="test-tpu",
* zone="us-central1-c",
* runtime_version="tpu-vm-tf-2.13.0")
* ```
* ```csharp
* using System.Collections.Generic;
* using System.Linq;
* using Pulumi;
* using Gcp = Pulumi.Gcp;
* return await Deployment.RunAsync(() =>
* {
* var available = Gcp.Tpu.GetV2RuntimeVersions.Invoke();
* var tpu = new Gcp.Tpu.V2Vm("tpu", new()
* {
* Name = "test-tpu",
* Zone = "us-central1-c",
* RuntimeVersion = "tpu-vm-tf-2.13.0",
* });
* });
* ```
* ```go
* package main
* import (
* "github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/tpu"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* _, err := tpu.GetV2RuntimeVersions(ctx, nil, nil)
* if err != nil {
* return err
* }
* _, err = tpu.NewV2Vm(ctx, "tpu", &tpu.V2VmArgs{
* Name: pulumi.String("test-tpu"),
* Zone: pulumi.String("us-central1-c"),
* RuntimeVersion: pulumi.String("tpu-vm-tf-2.13.0"),
* })
* if err != nil {
* return err
* }
* return nil
* })
* }
* ```
* ```java
* package generated_program;
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.gcp.tpu.TpuFunctions;
* import com.pulumi.gcp.tpu.inputs.GetV2RuntimeVersionsArgs;
* import com.pulumi.gcp.tpu.V2Vm;
* import com.pulumi.gcp.tpu.V2VmArgs;
* import java.util.List;
* import java.util.ArrayList;
* import java.util.Map;
* import java.io.File;
* import java.nio.file.Files;
* import java.nio.file.Paths;
* public class App {
* public static void main(String[] args) {
* Pulumi.run(App::stack);
* }
* public static void stack(Context ctx) {
* final var available = TpuFunctions.getV2RuntimeVersions();
* var tpu = new V2Vm("tpu", V2VmArgs.builder()
* .name("test-tpu")
* .zone("us-central1-c")
* .runtimeVersion("tpu-vm-tf-2.13.0")
* .build());
* }
* }
* ```
* ```yaml
* resources:
* tpu:
* type: gcp:tpu:V2Vm
* properties:
* name: test-tpu
* zone: us-central1-c
* runtimeVersion: tpu-vm-tf-2.13.0
* variables:
* available:
* fn::invoke:
* Function: gcp:tpu:getV2RuntimeVersions
* Arguments: {}
* ```
*
* ### Tpu V2 Vm Full
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as gcp from "@pulumi/gcp";
* import * as time from "@pulumi/time";
* const available = gcp.tpu.getV2RuntimeVersions({});
* const availableGetV2AcceleratorTypes = gcp.tpu.getV2AcceleratorTypes({});
* const network = new gcp.compute.Network("network", {
* name: "tpu-net",
* autoCreateSubnetworks: false,
* });
* const subnet = new gcp.compute.Subnetwork("subnet", {
* name: "tpu-subnet",
* ipCidrRange: "10.0.0.0/16",
* region: "us-central1",
* network: network.id,
* });
* const sa = new gcp.serviceaccount.Account("sa", {
* accountId: "tpu-sa",
* displayName: "Test TPU VM",
* });
* const disk = new gcp.compute.Disk("disk", {
* name: "tpu-disk",
* image: "debian-cloud/debian-11",
* size: 10,
* type: "pd-ssd",
* zone: "us-central1-c",
* });
* const tpu = new gcp.tpu.V2Vm("tpu", {
* name: "test-tpu",
* zone: "us-central1-c",
* description: "Text description of the TPU.",
* runtimeVersion: "tpu-vm-tf-2.13.0",
* acceleratorConfig: {
* type: "V2",
* topology: "2x2",
* },
* cidrBlock: "10.0.0.0/29",
* networkConfig: {
* canIpForward: true,
* enableExternalIps: true,
* network: network.id,
* subnetwork: subnet.id,
* },
* schedulingConfig: {
* preemptible: true,
* },
* shieldedInstanceConfig: {
* enableSecureBoot: true,
* },
* serviceAccount: {
* email: sa.email,
* scopes: ["https://www.googleapis.com/auth/cloud-platform"],
* },
* dataDisks: [{
* sourceDisk: disk.id,
* mode: "READ_ONLY",
* }],
* labels: {
* foo: "bar",
* },
* metadata: {
* foo: "bar",
* },
* tags: ["foo"],
* });
* // Wait after service account creation to limit eventual consistency errors.
* const wait60Seconds = new time.index.Sleep("wait_60_seconds", {createDuration: "60s"});
* ```
* ```python
* import pulumi
* import pulumi_gcp as gcp
* import pulumi_time as time
* available = gcp.tpu.get_v2_runtime_versions()
* available_get_v2_accelerator_types = gcp.tpu.get_v2_accelerator_types()
* network = gcp.compute.Network("network",
* name="tpu-net",
* auto_create_subnetworks=False)
* subnet = gcp.compute.Subnetwork("subnet",
* name="tpu-subnet",
* ip_cidr_range="10.0.0.0/16",
* region="us-central1",
* network=network.id)
* sa = gcp.serviceaccount.Account("sa",
* account_id="tpu-sa",
* display_name="Test TPU VM")
* disk = gcp.compute.Disk("disk",
* name="tpu-disk",
* image="debian-cloud/debian-11",
* size=10,
* type="pd-ssd",
* zone="us-central1-c")
* tpu = gcp.tpu.V2Vm("tpu",
* name="test-tpu",
* zone="us-central1-c",
* description="Text description of the TPU.",
* runtime_version="tpu-vm-tf-2.13.0",
* accelerator_config=gcp.tpu.V2VmAcceleratorConfigArgs(
* type="V2",
* topology="2x2",
* ),
* cidr_block="10.0.0.0/29",
* network_config=gcp.tpu.V2VmNetworkConfigArgs(
* can_ip_forward=True,
* enable_external_ips=True,
* network=network.id,
* subnetwork=subnet.id,
* ),
* scheduling_config=gcp.tpu.V2VmSchedulingConfigArgs(
* preemptible=True,
* ),
* shielded_instance_config=gcp.tpu.V2VmShieldedInstanceConfigArgs(
* enable_secure_boot=True,
* ),
* service_account=gcp.tpu.V2VmServiceAccountArgs(
* email=sa.email,
* scopes=["https://www.googleapis.com/auth/cloud-platform"],
* ),
* data_disks=[gcp.tpu.V2VmDataDiskArgs(
* source_disk=disk.id,
* mode="READ_ONLY",
* )],
* labels={
* "foo": "bar",
* },
* metadata={
* "foo": "bar",
* },
* tags=["foo"])
* # Wait after service account creation to limit eventual consistency errors.
* wait60_seconds = time.index.Sleep("wait_60_seconds", create_duration=60s)
* ```
* ```csharp
* using System.Collections.Generic;
* using System.Linq;
* using Pulumi;
* using Gcp = Pulumi.Gcp;
* using Time = Pulumi.Time;
* return await Deployment.RunAsync(() =>
* {
* var available = Gcp.Tpu.GetV2RuntimeVersions.Invoke();
* var availableGetV2AcceleratorTypes = Gcp.Tpu.GetV2AcceleratorTypes.Invoke();
* var network = new Gcp.Compute.Network("network", new()
* {
* Name = "tpu-net",
* AutoCreateSubnetworks = false,
* });
* var subnet = new Gcp.Compute.Subnetwork("subnet", new()
* {
* Name = "tpu-subnet",
* IpCidrRange = "10.0.0.0/16",
* Region = "us-central1",
* Network = network.Id,
* });
* var sa = new Gcp.ServiceAccount.Account("sa", new()
* {
* AccountId = "tpu-sa",
* DisplayName = "Test TPU VM",
* });
* var disk = new Gcp.Compute.Disk("disk", new()
* {
* Name = "tpu-disk",
* Image = "debian-cloud/debian-11",
* Size = 10,
* Type = "pd-ssd",
* Zone = "us-central1-c",
* });
* var tpu = new Gcp.Tpu.V2Vm("tpu", new()
* {
* Name = "test-tpu",
* Zone = "us-central1-c",
* Description = "Text description of the TPU.",
* RuntimeVersion = "tpu-vm-tf-2.13.0",
* AcceleratorConfig = new Gcp.Tpu.Inputs.V2VmAcceleratorConfigArgs
* {
* Type = "V2",
* Topology = "2x2",
* },
* CidrBlock = "10.0.0.0/29",
* NetworkConfig = new Gcp.Tpu.Inputs.V2VmNetworkConfigArgs
* {
* CanIpForward = true,
* EnableExternalIps = true,
* Network = network.Id,
* Subnetwork = subnet.Id,
* },
* SchedulingConfig = new Gcp.Tpu.Inputs.V2VmSchedulingConfigArgs
* {
* Preemptible = true,
* },
* ShieldedInstanceConfig = new Gcp.Tpu.Inputs.V2VmShieldedInstanceConfigArgs
* {
* EnableSecureBoot = true,
* },
* ServiceAccount = new Gcp.Tpu.Inputs.V2VmServiceAccountArgs
* {
* Email = sa.Email,
* Scopes = new[]
* {
* "https://www.googleapis.com/auth/cloud-platform",
* },
* },
* DataDisks = new[]
* {
* new Gcp.Tpu.Inputs.V2VmDataDiskArgs
* {
* SourceDisk = disk.Id,
* Mode = "READ_ONLY",
* },
* },
* Labels =
* {
* { "foo", "bar" },
* },
* Metadata =
* {
* { "foo", "bar" },
* },
* Tags = new[]
* {
* "foo",
* },
* });
* // Wait after service account creation to limit eventual consistency errors.
* var wait60Seconds = new Time.Index.Sleep("wait_60_seconds", new()
* {
* CreateDuration = "60s",
* });
* });
* ```
* ```go
* package main
* import (
* "github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/compute"
* "github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/serviceaccount"
* "github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/tpu"
* "github.com/pulumi/pulumi-time/sdk/go/time"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* _, err := tpu.GetV2RuntimeVersions(ctx, nil, nil)
* if err != nil {
* return err
* }
* _, err = tpu.GetV2AcceleratorTypes(ctx, nil, nil)
* if err != nil {
* return err
* }
* network, err := compute.NewNetwork(ctx, "network", &compute.NetworkArgs{
* Name: pulumi.String("tpu-net"),
* AutoCreateSubnetworks: pulumi.Bool(false),
* })
* if err != nil {
* return err
* }
* subnet, err := compute.NewSubnetwork(ctx, "subnet", &compute.SubnetworkArgs{
* Name: pulumi.String("tpu-subnet"),
* IpCidrRange: pulumi.String("10.0.0.0/16"),
* Region: pulumi.String("us-central1"),
* Network: network.ID(),
* })
* if err != nil {
* return err
* }
* sa, err := serviceaccount.NewAccount(ctx, "sa", &serviceaccount.AccountArgs{
* AccountId: pulumi.String("tpu-sa"),
* DisplayName: pulumi.String("Test TPU VM"),
* })
* if err != nil {
* return err
* }
* disk, err := compute.NewDisk(ctx, "disk", &compute.DiskArgs{
* Name: pulumi.String("tpu-disk"),
* Image: pulumi.String("debian-cloud/debian-11"),
* Size: pulumi.Int(10),
* Type: pulumi.String("pd-ssd"),
* Zone: pulumi.String("us-central1-c"),
* })
* if err != nil {
* return err
* }
* _, err = tpu.NewV2Vm(ctx, "tpu", &tpu.V2VmArgs{
* Name: pulumi.String("test-tpu"),
* Zone: pulumi.String("us-central1-c"),
* Description: pulumi.String("Text description of the TPU."),
* RuntimeVersion: pulumi.String("tpu-vm-tf-2.13.0"),
* AcceleratorConfig: &tpu.V2VmAcceleratorConfigArgs{
* Type: pulumi.String("V2"),
* Topology: pulumi.String("2x2"),
* },
* CidrBlock: pulumi.String("10.0.0.0/29"),
* NetworkConfig: &tpu.V2VmNetworkConfigArgs{
* CanIpForward: pulumi.Bool(true),
* EnableExternalIps: pulumi.Bool(true),
* Network: network.ID(),
* Subnetwork: subnet.ID(),
* },
* SchedulingConfig: &tpu.V2VmSchedulingConfigArgs{
* Preemptible: pulumi.Bool(true),
* },
* ShieldedInstanceConfig: &tpu.V2VmShieldedInstanceConfigArgs{
* EnableSecureBoot: pulumi.Bool(true),
* },
* ServiceAccount: &tpu.V2VmServiceAccountArgs{
* Email: sa.Email,
* Scopes: pulumi.StringArray{
* pulumi.String("https://www.googleapis.com/auth/cloud-platform"),
* },
* },
* DataDisks: tpu.V2VmDataDiskArray{
* &tpu.V2VmDataDiskArgs{
* SourceDisk: disk.ID(),
* Mode: pulumi.String("READ_ONLY"),
* },
* },
* Labels: pulumi.StringMap{
* "foo": pulumi.String("bar"),
* },
* Metadata: pulumi.StringMap{
* "foo": pulumi.String("bar"),
* },
* Tags: pulumi.StringArray{
* pulumi.String("foo"),
* },
* })
* if err != nil {
* return err
* }
* // Wait after service account creation to limit eventual consistency errors.
* _, err = time.NewSleep(ctx, "wait_60_seconds", &time.SleepArgs{
* CreateDuration: "60s",
* })
* if err != nil {
* return err
* }
* return nil
* })
* }
* ```
* ```java
* package generated_program;
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.gcp.tpu.TpuFunctions;
* import com.pulumi.gcp.tpu.inputs.GetV2RuntimeVersionsArgs;
* import com.pulumi.gcp.tpu.inputs.GetV2AcceleratorTypesArgs;
* import com.pulumi.gcp.compute.Network;
* import com.pulumi.gcp.compute.NetworkArgs;
* import com.pulumi.gcp.compute.Subnetwork;
* import com.pulumi.gcp.compute.SubnetworkArgs;
* import com.pulumi.gcp.serviceaccount.Account;
* import com.pulumi.gcp.serviceaccount.AccountArgs;
* import com.pulumi.gcp.compute.Disk;
* import com.pulumi.gcp.compute.DiskArgs;
* import com.pulumi.gcp.tpu.V2Vm;
* import com.pulumi.gcp.tpu.V2VmArgs;
* import com.pulumi.gcp.tpu.inputs.V2VmAcceleratorConfigArgs;
* import com.pulumi.gcp.tpu.inputs.V2VmNetworkConfigArgs;
* import com.pulumi.gcp.tpu.inputs.V2VmSchedulingConfigArgs;
* import com.pulumi.gcp.tpu.inputs.V2VmShieldedInstanceConfigArgs;
* import com.pulumi.gcp.tpu.inputs.V2VmServiceAccountArgs;
* import com.pulumi.gcp.tpu.inputs.V2VmDataDiskArgs;
* import com.pulumi.time.sleep;
* import com.pulumi.time.SleepArgs;
* import java.util.List;
* import java.util.ArrayList;
* import java.util.Map;
* import java.io.File;
* import java.nio.file.Files;
* import java.nio.file.Paths;
* public class App {
* public static void main(String[] args) {
* Pulumi.run(App::stack);
* }
* public static void stack(Context ctx) {
* final var available = TpuFunctions.getV2RuntimeVersions();
* final var availableGetV2AcceleratorTypes = TpuFunctions.getV2AcceleratorTypes();
* var network = new Network("network", NetworkArgs.builder()
* .name("tpu-net")
* .autoCreateSubnetworks(false)
* .build());
* var subnet = new Subnetwork("subnet", SubnetworkArgs.builder()
* .name("tpu-subnet")
* .ipCidrRange("10.0.0.0/16")
* .region("us-central1")
* .network(network.id())
* .build());
* var sa = new Account("sa", AccountArgs.builder()
* .accountId("tpu-sa")
* .displayName("Test TPU VM")
* .build());
* var disk = new Disk("disk", DiskArgs.builder()
* .name("tpu-disk")
* .image("debian-cloud/debian-11")
* .size(10)
* .type("pd-ssd")
* .zone("us-central1-c")
* .build());
* var tpu = new V2Vm("tpu", V2VmArgs.builder()
* .name("test-tpu")
* .zone("us-central1-c")
* .description("Text description of the TPU.")
* .runtimeVersion("tpu-vm-tf-2.13.0")
* .acceleratorConfig(V2VmAcceleratorConfigArgs.builder()
* .type("V2")
* .topology("2x2")
* .build())
* .cidrBlock("10.0.0.0/29")
* .networkConfig(V2VmNetworkConfigArgs.builder()
* .canIpForward(true)
* .enableExternalIps(true)
* .network(network.id())
* .subnetwork(subnet.id())
* .build())
* .schedulingConfig(V2VmSchedulingConfigArgs.builder()
* .preemptible(true)
* .build())
* .shieldedInstanceConfig(V2VmShieldedInstanceConfigArgs.builder()
* .enableSecureBoot(true)
* .build())
* .serviceAccount(V2VmServiceAccountArgs.builder()
* .email(sa.email())
* .scopes("https://www.googleapis.com/auth/cloud-platform")
* .build())
* .dataDisks(V2VmDataDiskArgs.builder()
* .sourceDisk(disk.id())
* .mode("READ_ONLY")
* .build())
* .labels(Map.of("foo", "bar"))
* .metadata(Map.of("foo", "bar"))
* .tags("foo")
* .build());
* // Wait after service account creation to limit eventual consistency errors.
* var wait60Seconds = new Sleep("wait60Seconds", SleepArgs.builder()
* .createDuration("60s")
* .build());
* }
* }
* ```
* ```yaml
* resources:
* tpu:
* type: gcp:tpu:V2Vm
* properties:
* name: test-tpu
* zone: us-central1-c
* description: Text description of the TPU.
* runtimeVersion: tpu-vm-tf-2.13.0
* acceleratorConfig:
* type: V2
* topology: 2x2
* cidrBlock: 10.0.0.0/29
* networkConfig:
* canIpForward: true
* enableExternalIps: true
* network: ${network.id}
* subnetwork: ${subnet.id}
* schedulingConfig:
* preemptible: true
* shieldedInstanceConfig:
* enableSecureBoot: true
* serviceAccount:
* email: ${sa.email}
* scopes:
* - https://www.googleapis.com/auth/cloud-platform
* dataDisks:
* - sourceDisk: ${disk.id}
* mode: READ_ONLY
* labels:
* foo: bar
* metadata:
* foo: bar
* tags:
* - foo
* subnet:
* type: gcp:compute:Subnetwork
* properties:
* name: tpu-subnet
* ipCidrRange: 10.0.0.0/16
* region: us-central1
* network: ${network.id}
* network:
* type: gcp:compute:Network
* properties:
* name: tpu-net
* autoCreateSubnetworks: false
* sa:
* type: gcp:serviceaccount:Account
* properties:
* accountId: tpu-sa
* displayName: Test TPU VM
* disk:
* type: gcp:compute:Disk
* properties:
* name: tpu-disk
* image: debian-cloud/debian-11
* size: 10
* type: pd-ssd
* zone: us-central1-c
* # Wait after service account creation to limit eventual consistency errors.
* wait60Seconds:
* type: time:sleep
* name: wait_60_seconds
* properties:
* createDuration: 60s
* variables:
* available:
* fn::invoke:
* Function: gcp:tpu:getV2RuntimeVersions
* Arguments: {}
* availableGetV2AcceleratorTypes:
* fn::invoke:
* Function: gcp:tpu:getV2AcceleratorTypes
* Arguments: {}
* ```
*
* ## Import
* Vm can be imported using any of these accepted formats:
* * `projects/{{project}}/locations/{{zone}}/nodes/{{name}}`
* * `{{project}}/{{zone}}/{{name}}`
* * `{{zone}}/{{name}}`
* * `{{name}}`
* When using the `pulumi import` command, Vm can be imported using one of the formats above. For example:
* ```sh
* $ pulumi import gcp:tpu/v2Vm:V2Vm default projects/{{project}}/locations/{{zone}}/nodes/{{name}}
* ```
* ```sh
* $ pulumi import gcp:tpu/v2Vm:V2Vm default {{project}}/{{zone}}/{{name}}
* ```
* ```sh
* $ pulumi import gcp:tpu/v2Vm:V2Vm default {{zone}}/{{name}}
* ```
* ```sh
* $ pulumi import gcp:tpu/v2Vm:V2Vm default {{name}}
* ```
*/
public class V2Vm internal constructor(
override val javaResource: com.pulumi.gcp.tpu.V2Vm,
) : KotlinCustomResource(javaResource, V2VmMapper) {
/**
* The AccleratorConfig for the TPU Node. `accelerator_config` cannot be used at the same time
* as `accelerator_type`. If neither is specified, `accelerator_type` defaults to 'v2-8'.
* Structure is documented below.
*/
public val acceleratorConfig: Output
get() = javaResource.acceleratorConfig().applyValue({ args0 ->
args0.let({ args0 ->
v2VmAcceleratorConfigToKotlin(args0)
})
})
/**
* TPU accelerator type for the TPU. `accelerator_type` cannot be used at the same time as
* `accelerator_config`. If neither is specified, `accelerator_type` defaults to 'v2-8'.
*/
public val acceleratorType: Output
get() = javaResource.acceleratorType().applyValue({ args0 -> args0 })
/**
* The API version that created this Node.
*/
public val apiVersion: Output
get() = javaResource.apiVersion().applyValue({ args0 -> args0 })
/**
* The CIDR block that the TPU node will use when selecting an IP address. This CIDR block must
* be a /29 block; the Compute Engine networks API forbids a smaller block, and using a larger
* block would be wasteful (a node can only consume one IP address). Errors will occur if the
* CIDR block has already been used for a currently existing TPU node, the CIDR block conflicts
* with any subnetworks in the user's provided network, or the provided network is peered with
* another network that is using that CIDR block.
*/
public val cidrBlock: Output
get() = javaResource.cidrBlock().applyValue({ args0 -> args0 })
/**
* The additional data disks for the Node.
* Structure is documented below.
*/
public val dataDisks: Output>?
get() = javaResource.dataDisks().applyValue({ args0 ->
args0.map({ args0 ->
args0.map({ args0 ->
args0.let({ args0 -> v2VmDataDiskToKotlin(args0) })
})
}).orElse(null)
})
/**
* Text description of the TPU.
*/
public val description: Output?
get() = javaResource.description().applyValue({ args0 ->
args0.map({ args0 ->
args0
}).orElse(null)
})
/**
* All of labels (key/value pairs) present on the resource in GCP, including the labels configured through Pulumi, other clients and services.
*/
public val effectiveLabels: Output
© 2015 - 2025 Weber Informatics LLC | Privacy Policy