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

com.pulumi.gcp.compute.kotlin.outputs.RegionInstanceGroupManagerUpdatePolicy.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.12.0.0
Show newest version
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.gcp.compute.kotlin.outputs

import kotlin.Int
import kotlin.String
import kotlin.Suppress

/**
 *
 * @property instanceRedistributionType The instance redistribution policy for regional managed instance groups. Valid values are: `"PROACTIVE"`, `"NONE"`. If `PROACTIVE` (default), the group attempts to maintain an even distribution of VM instances across zones in the region. If `NONE`, proactive redistribution is disabled.
 * @property maxSurgeFixed , The maximum number of instances that can be created above the specified targetSize during the update process. Conflicts with `max_surge_percent`. It has to be either 0 or at least equal to the number of zones.  If fixed values are used, at least one of `max_unavailable_fixed` or `max_surge_fixed` must be greater than 0.
 * @property maxSurgePercent , The maximum number of instances(calculated as percentage) that can be created above the specified targetSize during the update process. Conflicts with `max_surge_fixed`. Percent value is only allowed for regional managed instance groups with size at least 10.
 * @property maxUnavailableFixed , The maximum number of instances that can be unavailable during the update process. Conflicts with `max_unavailable_percent`. It has to be either 0 or at least equal to the number of zones. If fixed values are used, at least one of `max_unavailable_fixed` or `max_surge_fixed` must be greater than 0.
 * @property maxUnavailablePercent , The maximum number of instances(calculated as percentage) that can be unavailable during the update process. Conflicts with `max_unavailable_fixed`. Percent value is only allowed for regional managed instance groups with size at least 10.
 * @property minReadySec , Minimum number of seconds to wait for after a newly created instance becomes available. This value must be from range [0, 3600]
 * @property minimalAction Minimal action to be taken on an instance. You can specify either `REFRESH` to update without stopping instances, `RESTART` to restart existing instances or `REPLACE` to delete and create new instances from the target template. If you specify a `REFRESH`, the Updater will attempt to perform that action only. However, if the Updater determines that the minimal action you specify is not enough to perform the update, it might perform a more disruptive action.
 * @property mostDisruptiveAllowedAction Most disruptive action that is allowed to be taken on an instance. You can specify either NONE to forbid any actions, REFRESH to allow actions that do not need instance restart, RESTART to allow actions that can be applied without instance replacing or REPLACE to allow all possible actions. If the Updater determines that the minimal update action needed is more disruptive than most disruptive allowed action you specify it will not perform the update at all.
 * @property replacementMethod , The instance replacement method for managed instance groups. Valid values are: "RECREATE", "SUBSTITUTE". If SUBSTITUTE (default), the group replaces VM instances with new instances that have randomly generated names. If RECREATE, instance names are preserved.  You must also set max_unavailable_fixed or max_unavailable_percent to be greater than 0.
 * - - -
 * @property type The type of update process. You can specify either `PROACTIVE` so that the instance group manager proactively executes actions in order to bring instances to their target versions or `OPPORTUNISTIC` so that no action is proactively executed but the update will be performed as part of other actions (for example, resizes or recreateInstances calls).
 */
public data class RegionInstanceGroupManagerUpdatePolicy(
    public val instanceRedistributionType: String? = null,
    public val maxSurgeFixed: Int? = null,
    public val maxSurgePercent: Int? = null,
    public val maxUnavailableFixed: Int? = null,
    public val maxUnavailablePercent: Int? = null,
    public val minReadySec: Int? = null,
    public val minimalAction: String,
    public val mostDisruptiveAllowedAction: String? = null,
    public val replacementMethod: String? = null,
    public val type: String,
) {
    public companion object {
        public fun toKotlin(javaType: com.pulumi.gcp.compute.outputs.RegionInstanceGroupManagerUpdatePolicy): RegionInstanceGroupManagerUpdatePolicy = RegionInstanceGroupManagerUpdatePolicy(
            instanceRedistributionType = javaType.instanceRedistributionType().map({ args0 ->
                args0
            }).orElse(null),
            maxSurgeFixed = javaType.maxSurgeFixed().map({ args0 -> args0 }).orElse(null),
            maxSurgePercent = javaType.maxSurgePercent().map({ args0 -> args0 }).orElse(null),
            maxUnavailableFixed = javaType.maxUnavailableFixed().map({ args0 -> args0 }).orElse(null),
            maxUnavailablePercent = javaType.maxUnavailablePercent().map({ args0 -> args0 }).orElse(null),
            minReadySec = javaType.minReadySec().map({ args0 -> args0 }).orElse(null),
            minimalAction = javaType.minimalAction(),
            mostDisruptiveAllowedAction = javaType.mostDisruptiveAllowedAction().map({ args0 ->
                args0
            }).orElse(null),
            replacementMethod = javaType.replacementMethod().map({ args0 -> args0 }).orElse(null),
            type = javaType.type(),
        )
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy