All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.pulumi.gcp.compute.kotlin.InstanceGroupManager.kt Maven / Gradle / Ivy

Go to download

Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.

There is a newer version: 8.13.1.0
Show newest version
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.gcp.compute.kotlin

import com.pulumi.core.Output
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerAllInstancesConfig
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerAutoHealingPolicies
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerInstanceLifecyclePolicy
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerNamedPort
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerParams
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerStandbyPolicy
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerStatefulDisk
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerStatefulExternalIp
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerStatefulInternalIp
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerStatus
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerUpdatePolicy
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerVersion
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.Int
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerAllInstancesConfig.Companion.toKotlin as instanceGroupManagerAllInstancesConfigToKotlin
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerAutoHealingPolicies.Companion.toKotlin as instanceGroupManagerAutoHealingPoliciesToKotlin
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerInstanceLifecyclePolicy.Companion.toKotlin as instanceGroupManagerInstanceLifecyclePolicyToKotlin
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerNamedPort.Companion.toKotlin as instanceGroupManagerNamedPortToKotlin
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerParams.Companion.toKotlin as instanceGroupManagerParamsToKotlin
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerStandbyPolicy.Companion.toKotlin as instanceGroupManagerStandbyPolicyToKotlin
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerStatefulDisk.Companion.toKotlin as instanceGroupManagerStatefulDiskToKotlin
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerStatefulExternalIp.Companion.toKotlin as instanceGroupManagerStatefulExternalIpToKotlin
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerStatefulInternalIp.Companion.toKotlin as instanceGroupManagerStatefulInternalIpToKotlin
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerStatus.Companion.toKotlin as instanceGroupManagerStatusToKotlin
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerUpdatePolicy.Companion.toKotlin as instanceGroupManagerUpdatePolicyToKotlin
import com.pulumi.gcp.compute.kotlin.outputs.InstanceGroupManagerVersion.Companion.toKotlin as instanceGroupManagerVersionToKotlin

/**
 * Builder for [InstanceGroupManager].
 */
@PulumiTagMarker
public class InstanceGroupManagerResourceBuilder internal constructor() {
    public var name: String? = null

    public var args: InstanceGroupManagerArgs = InstanceGroupManagerArgs()

    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 InstanceGroupManagerArgsBuilder.() -> Unit) {
        val builder = InstanceGroupManagerArgsBuilder()
        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(): InstanceGroupManager {
        val builtJavaResource = com.pulumi.gcp.compute.InstanceGroupManager(
            this.name,
            this.args.toJava(),
            this.opts.toJava(),
        )
        return InstanceGroupManager(builtJavaResource)
    }
}

/**
 * The Google Compute Engine Instance Group Manager API creates and manages pools
 * of homogeneous Compute Engine virtual machine instances from a common instance
 * template. For more information, see [the official documentation](https://cloud.google.com/compute/docs/instance-groups/manager)
 * and [API](https://cloud.google.com/compute/docs/reference/latest/instanceGroupManagers)
 * > **Note:** Use [gcp.compute.RegionInstanceGroupManager](https://www.terraform.io/docs/providers/google/r/compute_region_instance_group_manager.html) to create a regional (multi-zone) instance group manager.
 * ## Example Usage
 * ### With Top Level Instance Template (`Google` Provider)
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const autohealing = new gcp.compute.HealthCheck("autohealing", {
 *     name: "autohealing-health-check",
 *     checkIntervalSec: 5,
 *     timeoutSec: 5,
 *     healthyThreshold: 2,
 *     unhealthyThreshold: 10,
 *     httpHealthCheck: {
 *         requestPath: "/healthz",
 *         port: 8080,
 *     },
 * });
 * const appserver = new gcp.compute.InstanceGroupManager("appserver", {
 *     name: "appserver-igm",
 *     baseInstanceName: "app",
 *     zone: "us-central1-a",
 *     versions: [{
 *         instanceTemplate: appserverGoogleComputeInstanceTemplate.selfLinkUnique,
 *     }],
 *     allInstancesConfig: {
 *         metadata: {
 *             metadata_key: "metadata_value",
 *         },
 *         labels: {
 *             label_key: "label_value",
 *         },
 *     },
 *     targetPools: [appserverGoogleComputeTargetPool.id],
 *     targetSize: 2,
 *     namedPorts: [{
 *         name: "customhttp",
 *         port: 8888,
 *     }],
 *     autoHealingPolicies: {
 *         healthCheck: autohealing.id,
 *         initialDelaySec: 300,
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * autohealing = gcp.compute.HealthCheck("autohealing",
 *     name="autohealing-health-check",
 *     check_interval_sec=5,
 *     timeout_sec=5,
 *     healthy_threshold=2,
 *     unhealthy_threshold=10,
 *     http_health_check={
 *         "request_path": "/healthz",
 *         "port": 8080,
 *     })
 * appserver = gcp.compute.InstanceGroupManager("appserver",
 *     name="appserver-igm",
 *     base_instance_name="app",
 *     zone="us-central1-a",
 *     versions=[{
 *         "instance_template": appserver_google_compute_instance_template["selfLinkUnique"],
 *     }],
 *     all_instances_config={
 *         "metadata": {
 *             "metadata_key": "metadata_value",
 *         },
 *         "labels": {
 *             "label_key": "label_value",
 *         },
 *     },
 *     target_pools=[appserver_google_compute_target_pool["id"]],
 *     target_size=2,
 *     named_ports=[{
 *         "name": "customhttp",
 *         "port": 8888,
 *     }],
 *     auto_healing_policies={
 *         "health_check": autohealing.id,
 *         "initial_delay_sec": 300,
 *     })
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var autohealing = new Gcp.Compute.HealthCheck("autohealing", new()
 *     {
 *         Name = "autohealing-health-check",
 *         CheckIntervalSec = 5,
 *         TimeoutSec = 5,
 *         HealthyThreshold = 2,
 *         UnhealthyThreshold = 10,
 *         HttpHealthCheck = new Gcp.Compute.Inputs.HealthCheckHttpHealthCheckArgs
 *         {
 *             RequestPath = "/healthz",
 *             Port = 8080,
 *         },
 *     });
 *     var appserver = new Gcp.Compute.InstanceGroupManager("appserver", new()
 *     {
 *         Name = "appserver-igm",
 *         BaseInstanceName = "app",
 *         Zone = "us-central1-a",
 *         Versions = new[]
 *         {
 *             new Gcp.Compute.Inputs.InstanceGroupManagerVersionArgs
 *             {
 *                 InstanceTemplate = appserverGoogleComputeInstanceTemplate.SelfLinkUnique,
 *             },
 *         },
 *         AllInstancesConfig = new Gcp.Compute.Inputs.InstanceGroupManagerAllInstancesConfigArgs
 *         {
 *             Metadata =
 *             {
 *                 { "metadata_key", "metadata_value" },
 *             },
 *             Labels =
 *             {
 *                 { "label_key", "label_value" },
 *             },
 *         },
 *         TargetPools = new[]
 *         {
 *             appserverGoogleComputeTargetPool.Id,
 *         },
 *         TargetSize = 2,
 *         NamedPorts = new[]
 *         {
 *             new Gcp.Compute.Inputs.InstanceGroupManagerNamedPortArgs
 *             {
 *                 Name = "customhttp",
 *                 Port = 8888,
 *             },
 *         },
 *         AutoHealingPolicies = new Gcp.Compute.Inputs.InstanceGroupManagerAutoHealingPoliciesArgs
 *         {
 *             HealthCheck = autohealing.Id,
 *             InitialDelaySec = 300,
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v8/go/gcp/compute"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		autohealing, err := compute.NewHealthCheck(ctx, "autohealing", &compute.HealthCheckArgs{
 * 			Name:               pulumi.String("autohealing-health-check"),
 * 			CheckIntervalSec:   pulumi.Int(5),
 * 			TimeoutSec:         pulumi.Int(5),
 * 			HealthyThreshold:   pulumi.Int(2),
 * 			UnhealthyThreshold: pulumi.Int(10),
 * 			HttpHealthCheck: &compute.HealthCheckHttpHealthCheckArgs{
 * 				RequestPath: pulumi.String("/healthz"),
 * 				Port:        pulumi.Int(8080),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = compute.NewInstanceGroupManager(ctx, "appserver", &compute.InstanceGroupManagerArgs{
 * 			Name:             pulumi.String("appserver-igm"),
 * 			BaseInstanceName: pulumi.String("app"),
 * 			Zone:             pulumi.String("us-central1-a"),
 * 			Versions: compute.InstanceGroupManagerVersionArray{
 * 				&compute.InstanceGroupManagerVersionArgs{
 * 					InstanceTemplate: pulumi.Any(appserverGoogleComputeInstanceTemplate.SelfLinkUnique),
 * 				},
 * 			},
 * 			AllInstancesConfig: &compute.InstanceGroupManagerAllInstancesConfigArgs{
 * 				Metadata: pulumi.StringMap{
 * 					"metadata_key": pulumi.String("metadata_value"),
 * 				},
 * 				Labels: pulumi.StringMap{
 * 					"label_key": pulumi.String("label_value"),
 * 				},
 * 			},
 * 			TargetPools: pulumi.StringArray{
 * 				appserverGoogleComputeTargetPool.Id,
 * 			},
 * 			TargetSize: pulumi.Int(2),
 * 			NamedPorts: compute.InstanceGroupManagerNamedPortArray{
 * 				&compute.InstanceGroupManagerNamedPortArgs{
 * 					Name: pulumi.String("customhttp"),
 * 					Port: pulumi.Int(8888),
 * 				},
 * 			},
 * 			AutoHealingPolicies: &compute.InstanceGroupManagerAutoHealingPoliciesArgs{
 * 				HealthCheck:     autohealing.ID(),
 * 				InitialDelaySec: pulumi.Int(300),
 * 			},
 * 		})
 * 		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.compute.HealthCheck;
 * import com.pulumi.gcp.compute.HealthCheckArgs;
 * import com.pulumi.gcp.compute.inputs.HealthCheckHttpHealthCheckArgs;
 * import com.pulumi.gcp.compute.InstanceGroupManager;
 * import com.pulumi.gcp.compute.InstanceGroupManagerArgs;
 * import com.pulumi.gcp.compute.inputs.InstanceGroupManagerVersionArgs;
 * import com.pulumi.gcp.compute.inputs.InstanceGroupManagerAllInstancesConfigArgs;
 * import com.pulumi.gcp.compute.inputs.InstanceGroupManagerNamedPortArgs;
 * import com.pulumi.gcp.compute.inputs.InstanceGroupManagerAutoHealingPoliciesArgs;
 * 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 autohealing = new HealthCheck("autohealing", HealthCheckArgs.builder()
 *             .name("autohealing-health-check")
 *             .checkIntervalSec(5)
 *             .timeoutSec(5)
 *             .healthyThreshold(2)
 *             .unhealthyThreshold(10)
 *             .httpHealthCheck(HealthCheckHttpHealthCheckArgs.builder()
 *                 .requestPath("/healthz")
 *                 .port("8080")
 *                 .build())
 *             .build());
 *         var appserver = new InstanceGroupManager("appserver", InstanceGroupManagerArgs.builder()
 *             .name("appserver-igm")
 *             .baseInstanceName("app")
 *             .zone("us-central1-a")
 *             .versions(InstanceGroupManagerVersionArgs.builder()
 *                 .instanceTemplate(appserverGoogleComputeInstanceTemplate.selfLinkUnique())
 *                 .build())
 *             .allInstancesConfig(InstanceGroupManagerAllInstancesConfigArgs.builder()
 *                 .metadata(Map.of("metadata_key", "metadata_value"))
 *                 .labels(Map.of("label_key", "label_value"))
 *                 .build())
 *             .targetPools(appserverGoogleComputeTargetPool.id())
 *             .targetSize(2)
 *             .namedPorts(InstanceGroupManagerNamedPortArgs.builder()
 *                 .name("customhttp")
 *                 .port(8888)
 *                 .build())
 *             .autoHealingPolicies(InstanceGroupManagerAutoHealingPoliciesArgs.builder()
 *                 .healthCheck(autohealing.id())
 *                 .initialDelaySec(300)
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   autohealing:
 *     type: gcp:compute:HealthCheck
 *     properties:
 *       name: autohealing-health-check
 *       checkIntervalSec: 5
 *       timeoutSec: 5
 *       healthyThreshold: 2
 *       unhealthyThreshold: 10 # 50 seconds
 *       httpHealthCheck:
 *         requestPath: /healthz
 *         port: '8080'
 *   appserver:
 *     type: gcp:compute:InstanceGroupManager
 *     properties:
 *       name: appserver-igm
 *       baseInstanceName: app
 *       zone: us-central1-a
 *       versions:
 *         - instanceTemplate: ${appserverGoogleComputeInstanceTemplate.selfLinkUnique}
 *       allInstancesConfig:
 *         metadata:
 *           metadata_key: metadata_value
 *         labels:
 *           label_key: label_value
 *       targetPools:
 *         - ${appserverGoogleComputeTargetPool.id}
 *       targetSize: 2
 *       namedPorts:
 *         - name: customhttp
 *           port: 8888
 *       autoHealingPolicies:
 *         healthCheck: ${autohealing.id}
 *         initialDelaySec: 300
 * ```
 * 
 * ### With Multiple Versions (`Google-Beta` Provider)
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const appserver = new gcp.compute.InstanceGroupManager("appserver", {
 *     name: "appserver-igm",
 *     baseInstanceName: "app",
 *     zone: "us-central1-a",
 *     targetSize: 5,
 *     versions: [
 *         {
 *             name: "appserver",
 *             instanceTemplate: appserverGoogleComputeInstanceTemplate.selfLinkUnique,
 *         },
 *         {
 *             name: "appserver-canary",
 *             instanceTemplate: appserver_canary.selfLinkUnique,
 *             targetSize: {
 *                 fixed: 1,
 *             },
 *         },
 *     ],
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * appserver = gcp.compute.InstanceGroupManager("appserver",
 *     name="appserver-igm",
 *     base_instance_name="app",
 *     zone="us-central1-a",
 *     target_size=5,
 *     versions=[
 *         {
 *             "name": "appserver",
 *             "instance_template": appserver_google_compute_instance_template["selfLinkUnique"],
 *         },
 *         {
 *             "name": "appserver-canary",
 *             "instance_template": appserver_canary["selfLinkUnique"],
 *             "target_size": {
 *                 "fixed": 1,
 *             },
 *         },
 *     ])
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var appserver = new Gcp.Compute.InstanceGroupManager("appserver", new()
 *     {
 *         Name = "appserver-igm",
 *         BaseInstanceName = "app",
 *         Zone = "us-central1-a",
 *         TargetSize = 5,
 *         Versions = new[]
 *         {
 *             new Gcp.Compute.Inputs.InstanceGroupManagerVersionArgs
 *             {
 *                 Name = "appserver",
 *                 InstanceTemplate = appserverGoogleComputeInstanceTemplate.SelfLinkUnique,
 *             },
 *             new Gcp.Compute.Inputs.InstanceGroupManagerVersionArgs
 *             {
 *                 Name = "appserver-canary",
 *                 InstanceTemplate = appserver_canary.SelfLinkUnique,
 *                 TargetSize = new Gcp.Compute.Inputs.InstanceGroupManagerVersionTargetSizeArgs
 *                 {
 *                     Fixed = 1,
 *                 },
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v8/go/gcp/compute"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := compute.NewInstanceGroupManager(ctx, "appserver", &compute.InstanceGroupManagerArgs{
 * 			Name:             pulumi.String("appserver-igm"),
 * 			BaseInstanceName: pulumi.String("app"),
 * 			Zone:             pulumi.String("us-central1-a"),
 * 			TargetSize:       pulumi.Int(5),
 * 			Versions: compute.InstanceGroupManagerVersionArray{
 * 				&compute.InstanceGroupManagerVersionArgs{
 * 					Name:             pulumi.String("appserver"),
 * 					InstanceTemplate: pulumi.Any(appserverGoogleComputeInstanceTemplate.SelfLinkUnique),
 * 				},
 * 				&compute.InstanceGroupManagerVersionArgs{
 * 					Name:             pulumi.String("appserver-canary"),
 * 					InstanceTemplate: pulumi.Any(appserver_canary.SelfLinkUnique),
 * 					TargetSize: &compute.InstanceGroupManagerVersionTargetSizeArgs{
 * 						Fixed: pulumi.Int(1),
 * 					},
 * 				},
 * 			},
 * 		})
 * 		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.compute.InstanceGroupManager;
 * import com.pulumi.gcp.compute.InstanceGroupManagerArgs;
 * import com.pulumi.gcp.compute.inputs.InstanceGroupManagerVersionArgs;
 * import com.pulumi.gcp.compute.inputs.InstanceGroupManagerVersionTargetSizeArgs;
 * 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 appserver = new InstanceGroupManager("appserver", InstanceGroupManagerArgs.builder()
 *             .name("appserver-igm")
 *             .baseInstanceName("app")
 *             .zone("us-central1-a")
 *             .targetSize(5)
 *             .versions(
 *                 InstanceGroupManagerVersionArgs.builder()
 *                     .name("appserver")
 *                     .instanceTemplate(appserverGoogleComputeInstanceTemplate.selfLinkUnique())
 *                     .build(),
 *                 InstanceGroupManagerVersionArgs.builder()
 *                     .name("appserver-canary")
 *                     .instanceTemplate(appserver_canary.selfLinkUnique())
 *                     .targetSize(InstanceGroupManagerVersionTargetSizeArgs.builder()
 *                         .fixed(1)
 *                         .build())
 *                     .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   appserver:
 *     type: gcp:compute:InstanceGroupManager
 *     properties:
 *       name: appserver-igm
 *       baseInstanceName: app
 *       zone: us-central1-a
 *       targetSize: 5
 *       versions:
 *         - name: appserver
 *           instanceTemplate: ${appserverGoogleComputeInstanceTemplate.selfLinkUnique}
 *         - name: appserver-canary
 *           instanceTemplate: ${["appserver-canary"].selfLinkUnique}
 *           targetSize:
 *             fixed: 1
 * ```
 * 
 * ### With Standby Policy (`Google-Beta` Provider)
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const igm_sr = new gcp.compute.InstanceGroupManager("igm-sr", {
 *     name: "tf-sr-igm",
 *     baseInstanceName: "tf-sr-igm-instance",
 *     zone: "us-central1-a",
 *     targetSize: 5,
 *     versions: [{
 *         instanceTemplate: sr_igm.selfLink,
 *         name: "primary",
 *     }],
 *     standbyPolicy: {
 *         initialDelaySec: 30,
 *         mode: "MANUAL",
 *     },
 *     targetSuspendedSize: 2,
 *     targetStoppedSize: 1,
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * igm_sr = gcp.compute.InstanceGroupManager("igm-sr",
 *     name="tf-sr-igm",
 *     base_instance_name="tf-sr-igm-instance",
 *     zone="us-central1-a",
 *     target_size=5,
 *     versions=[{
 *         "instance_template": sr_igm["selfLink"],
 *         "name": "primary",
 *     }],
 *     standby_policy={
 *         "initial_delay_sec": 30,
 *         "mode": "MANUAL",
 *     },
 *     target_suspended_size=2,
 *     target_stopped_size=1)
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var igm_sr = new Gcp.Compute.InstanceGroupManager("igm-sr", new()
 *     {
 *         Name = "tf-sr-igm",
 *         BaseInstanceName = "tf-sr-igm-instance",
 *         Zone = "us-central1-a",
 *         TargetSize = 5,
 *         Versions = new[]
 *         {
 *             new Gcp.Compute.Inputs.InstanceGroupManagerVersionArgs
 *             {
 *                 InstanceTemplate = sr_igm.SelfLink,
 *                 Name = "primary",
 *             },
 *         },
 *         StandbyPolicy = new Gcp.Compute.Inputs.InstanceGroupManagerStandbyPolicyArgs
 *         {
 *             InitialDelaySec = 30,
 *             Mode = "MANUAL",
 *         },
 *         TargetSuspendedSize = 2,
 *         TargetStoppedSize = 1,
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v8/go/gcp/compute"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := compute.NewInstanceGroupManager(ctx, "igm-sr", &compute.InstanceGroupManagerArgs{
 * 			Name:             pulumi.String("tf-sr-igm"),
 * 			BaseInstanceName: pulumi.String("tf-sr-igm-instance"),
 * 			Zone:             pulumi.String("us-central1-a"),
 * 			TargetSize:       pulumi.Int(5),
 * 			Versions: compute.InstanceGroupManagerVersionArray{
 * 				&compute.InstanceGroupManagerVersionArgs{
 * 					InstanceTemplate: pulumi.Any(sr_igm.SelfLink),
 * 					Name:             pulumi.String("primary"),
 * 				},
 * 			},
 * 			StandbyPolicy: &compute.InstanceGroupManagerStandbyPolicyArgs{
 * 				InitialDelaySec: pulumi.Int(30),
 * 				Mode:            pulumi.String("MANUAL"),
 * 			},
 * 			TargetSuspendedSize: pulumi.Int(2),
 * 			TargetStoppedSize:   pulumi.Int(1),
 * 		})
 * 		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.compute.InstanceGroupManager;
 * import com.pulumi.gcp.compute.InstanceGroupManagerArgs;
 * import com.pulumi.gcp.compute.inputs.InstanceGroupManagerVersionArgs;
 * import com.pulumi.gcp.compute.inputs.InstanceGroupManagerStandbyPolicyArgs;
 * 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 igm_sr = new InstanceGroupManager("igm-sr", InstanceGroupManagerArgs.builder()
 *             .name("tf-sr-igm")
 *             .baseInstanceName("tf-sr-igm-instance")
 *             .zone("us-central1-a")
 *             .targetSize(5)
 *             .versions(InstanceGroupManagerVersionArgs.builder()
 *                 .instanceTemplate(sr_igm.selfLink())
 *                 .name("primary")
 *                 .build())
 *             .standbyPolicy(InstanceGroupManagerStandbyPolicyArgs.builder()
 *                 .initialDelaySec(30)
 *                 .mode("MANUAL")
 *                 .build())
 *             .targetSuspendedSize(2)
 *             .targetStoppedSize(1)
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   igm-sr:
 *     type: gcp:compute:InstanceGroupManager
 *     properties:
 *       name: tf-sr-igm
 *       baseInstanceName: tf-sr-igm-instance
 *       zone: us-central1-a
 *       targetSize: 5
 *       versions:
 *         - instanceTemplate: ${["sr-igm"].selfLink}
 *           name: primary
 *       standbyPolicy:
 *         initialDelaySec: 30
 *         mode: MANUAL
 *       targetSuspendedSize: 2
 *       targetStoppedSize: 1
 * ```
 * 
 * ## Import
 * Instance group managers can be imported using any of these accepted formats:
 * * `projects/{{project}}/zones/{{zone}}/instanceGroupManagers/{{name}}`
 * * `{{project}}/{{zone}}/{{name}}`
 * * `{{project}}/{{name}}`
 * * `{{name}}`
 * When using the `pulumi import` command, instance group managers can be imported using one of the formats above. For example:
 * ```sh
 * $ pulumi import gcp:compute/instanceGroupManager:InstanceGroupManager default projects/{{project}}/zones/{{zone}}/instanceGroupManagers/{{name}}
 * ```
 * ```sh
 * $ pulumi import gcp:compute/instanceGroupManager:InstanceGroupManager default {{project}}/{{zone}}/{{name}}
 * ```
 * ```sh
 * $ pulumi import gcp:compute/instanceGroupManager:InstanceGroupManager default {{project}}/{{name}}
 * ```
 * ```sh
 * $ pulumi import gcp:compute/instanceGroupManager:InstanceGroupManager default {{name}}
 * ```
 */
public class InstanceGroupManager internal constructor(
    override val javaResource: com.pulumi.gcp.compute.InstanceGroupManager,
) : KotlinCustomResource(javaResource, InstanceGroupManagerMapper) {
    /**
     * Properties to set on all instances in the group. After setting
     * allInstancesConfig on the group, you must update the group's instances to
     * apply the configuration.
     */
    public val allInstancesConfig: Output?
        get() = javaResource.allInstancesConfig().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 -> instanceGroupManagerAllInstancesConfigToKotlin(args0) })
            }).orElse(null)
        })

    /**
     * The autohealing policies for this managed instance
     * group. You can specify only one value. Structure is documented below. For more information, see the [official documentation](https://cloud.google.com/compute/docs/instance-groups/creating-groups-of-managed-instances#monitoring_groups).
     */
    public val autoHealingPolicies: Output?
        get() = javaResource.autoHealingPolicies().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    instanceGroupManagerAutoHealingPoliciesToKotlin(args0)
                })
            }).orElse(null)
        })

    /**
     * The base instance name to use for
     * instances in this group. The value must be a valid
     * [RFC1035](https://www.ietf.org/rfc/rfc1035.txt) name. Supported characters
     * are lowercase letters, numbers, and hyphens (-). Instances are named by
     * appending a hyphen and a random four-character string to the base instance
     * name.
     */
    public val baseInstanceName: Output
        get() = javaResource.baseInstanceName().applyValue({ args0 -> args0 })

    /**
     * Creation timestamp in RFC3339 text format.
     */
    public val creationTimestamp: Output
        get() = javaResource.creationTimestamp().applyValue({ args0 -> args0 })

    /**
     * An optional textual description of the instance
     * group manager.
     */
    public val description: Output?
        get() = javaResource.description().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * The fingerprint of the instance group manager.
     */
    public val fingerprint: Output
        get() = javaResource.fingerprint().applyValue({ args0 -> args0 })

    /**
     * The full URL of the instance group created by the manager.
     */
    public val instanceGroup: Output
        get() = javaResource.instanceGroup().applyValue({ args0 -> args0 })

    /**
     * The unique identifier number for the resource. This identifier is defined by the server.
     */
    public val instanceGroupManagerId: Output
        get() = javaResource.instanceGroupManagerId().applyValue({ args0 -> args0 })

    /**
     * The instance lifecycle policy for this managed instance group.
     */
    public val instanceLifecyclePolicy: Output
        get() = javaResource.instanceLifecyclePolicy().applyValue({ args0 ->
            args0.let({ args0 ->
                instanceGroupManagerInstanceLifecyclePolicyToKotlin(args0)
            })
        })

    /**
     * Pagination behavior of the `listManagedInstances` API
     * method for this managed instance group. Valid values are: `PAGELESS`, `PAGINATED`.
     * If `PAGELESS` (default), Pagination is disabled for the group's `listManagedInstances` API method.
     * `maxResults` and `pageToken` query parameters are ignored and all instances are returned in a single
     * response. If `PAGINATED`, pagination is enabled, `maxResults` and `pageToken` query parameters are
     * respected.
     */
    public val listManagedInstancesResults: Output?
        get() = javaResource.listManagedInstancesResults().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * The name of the instance group manager. Must be 1-63
     * characters long and comply with
     * [RFC1035](https://www.ietf.org/rfc/rfc1035.txt). Supported characters
     * include lowercase letters, numbers, and hyphens.
     */
    public val name: Output
        get() = javaResource.name().applyValue({ args0 -> args0 })

    /**
     * The named port configuration. See the section below
     * for details on configuration.
     */
    public val namedPorts: Output>?
        get() = javaResource.namedPorts().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.map({ args0 ->
                    args0.let({ args0 -> instanceGroupManagerNamedPortToKotlin(args0) })
                })
            }).orElse(null)
        })

    public val operation: Output
        get() = javaResource.operation().applyValue({ args0 -> args0 })

    /**
     * Input only additional params for instance group manager creation. Structure is documented below. For more information, see [API](https://cloud.google.com/compute/docs/reference/rest/beta/instanceGroupManagers/insert).
     * - - -
     */
    public val params: Output?
        get() = javaResource.params().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    instanceGroupManagerParamsToKotlin(args0)
                })
            }).orElse(null)
        })

    /**
     * The ID of the project in which the resource belongs. If it
     * is not provided, the provider project is used.
     */
    public val project: Output
        get() = javaResource.project().applyValue({ args0 -> args0 })

    /**
     * The URL of the created resource.
     */
    public val selfLink: Output
        get() = javaResource.selfLink().applyValue({ args0 -> args0 })

    /**
     * The standby policy for stopped and suspended instances. Structure is documented below. For more information, see the [official documentation](https://cloud.google.com/compute/docs/instance-groups/suspended-and-stopped-vms-in-mig) and [API](https://cloud.google.com/compute/docs/reference/rest/beta/regionInstanceGroupManagers/patch)
     */
    public val standbyPolicy: Output
        get() = javaResource.standbyPolicy().applyValue({ args0 ->
            args0.let({ args0 ->
                instanceGroupManagerStandbyPolicyToKotlin(args0)
            })
        })

    /**
     * Disks created on the instances that will be preserved on instance delete, update, etc. Structure is documented below. For more information see the [official documentation](https://cloud.google.com/compute/docs/instance-groups/configuring-stateful-disks-in-migs).
     */
    public val statefulDisks: Output>?
        get() = javaResource.statefulDisks().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.map({ args0 ->
                    args0.let({ args0 ->
                        instanceGroupManagerStatefulDiskToKotlin(args0)
                    })
                })
            }).orElse(null)
        })

    /**
     * External network IPs assigned to the instances that will be preserved on instance delete, update, etc. This map is keyed with the network interface name. Structure is documented below.
     */
    public val statefulExternalIps: Output>?
        get() = javaResource.statefulExternalIps().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.map({ args0 ->
                    args0.let({ args0 ->
                        instanceGroupManagerStatefulExternalIpToKotlin(args0)
                    })
                })
            }).orElse(null)
        })

    /**
     * Internal network IPs assigned to the instances that will be preserved on instance delete, update, etc. This map is keyed with the network interface name. Structure is documented below.
     */
    public val statefulInternalIps: Output>?
        get() = javaResource.statefulInternalIps().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.map({ args0 ->
                    args0.let({ args0 ->
                        instanceGroupManagerStatefulInternalIpToKotlin(args0)
                    })
                })
            }).orElse(null)
        })

    /**
     * The status of this managed instance group.
     */
    public val statuses: Output>
        get() = javaResource.statuses().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    instanceGroupManagerStatusToKotlin(args0)
                })
            })
        })

    /**
     * The full URL of all target pools to which new
     * instances in the group are added. Updating the target pools attribute does
     * not affect existing instances.
     */
    public val targetPools: Output>?
        get() = javaResource.targetPools().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.map({ args0 ->
                    args0
                })
            }).orElse(null)
        })

    /**
     * The target number of running instances for this managed instance group. This value should always be explicitly set
     * unless this resource is attached to an autoscaler, in which case it should never be set. Defaults to 0.
     */
    public val targetSize: Output
        get() = javaResource.targetSize().applyValue({ args0 -> args0 })

    /**
     * The target number of stopped instances for this managed instance group.
     */
    public val targetStoppedSize: Output
        get() = javaResource.targetStoppedSize().applyValue({ args0 -> args0 })

    /**
     * The target number of suspended instances for this managed instance group.
     */
    public val targetSuspendedSize: Output
        get() = javaResource.targetSuspendedSize().applyValue({ args0 -> args0 })

    /**
     * The update policy for this managed instance group. Structure is documented below. For more information, see the [official documentation](https://cloud.google.com/compute/docs/instance-groups/updating-managed-instance-groups) and [API](https://cloud.google.com/compute/docs/reference/rest/v1/instanceGroupManagers/patch).
     */
    public val updatePolicy: Output
        get() = javaResource.updatePolicy().applyValue({ args0 ->
            args0.let({ args0 ->
                instanceGroupManagerUpdatePolicyToKotlin(args0)
            })
        })

    /**
     * Application versions managed by this instance group. Each
     * version deals with a specific instance template, allowing canary release scenarios.
     * Structure is documented below.
     */
    public val versions: Output>
        get() = javaResource.versions().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    instanceGroupManagerVersionToKotlin(args0)
                })
            })
        })

    /**
     * Whether to wait for all instances to be created/updated before
     * returning. Note that if this is set to true and the operation does not succeed, this provider will
     * continue trying until it times out.
     */
    public val waitForInstances: Output?
        get() = javaResource.waitForInstances().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * When used with `wait_for_instances` it specifies the status to wait for.
     * When `STABLE` is specified this resource will wait until the instances are stable before returning. When `UPDATED` is
     * set, it will wait for the version target to be reached and any per instance configs to be effective as well as all
     * instances to be stable before returning. The possible values are `STABLE` and `UPDATED`
     */
    public val waitForInstancesStatus: Output?
        get() = javaResource.waitForInstancesStatus().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * The zone that instances in this group should be created
     * in.
     * - - -
     */
    public val zone: Output
        get() = javaResource.zone().applyValue({ args0 -> args0 })
}

public object InstanceGroupManagerMapper : ResourceMapper {
    override fun supportsMappingOfType(javaResource: Resource): Boolean =
        com.pulumi.gcp.compute.InstanceGroupManager::class == javaResource::class

    override fun map(javaResource: Resource): InstanceGroupManager = InstanceGroupManager(
        javaResource
            as com.pulumi.gcp.compute.InstanceGroupManager,
    )
}

/**
 * @see [InstanceGroupManager].
 * @param name The _unique_ name of the resulting resource.
 * @param block Builder for [InstanceGroupManager].
 */
public suspend fun instanceGroupManager(
    name: String,
    block: suspend InstanceGroupManagerResourceBuilder.() -> Unit,
): InstanceGroupManager {
    val builder = InstanceGroupManagerResourceBuilder()
    builder.name(name)
    block(builder)
    return builder.build()
}

/**
 * @see [InstanceGroupManager].
 * @param name The _unique_ name of the resulting resource.
 */
public fun instanceGroupManager(name: String): InstanceGroupManager {
    val builder = InstanceGroupManagerResourceBuilder()
    builder.name(name)
    return builder.build()
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy