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

com.pulumi.gcp.compute.kotlin.inputs.RegionBackendServiceBackendArgs.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.inputs

import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.gcp.compute.inputs.RegionBackendServiceBackendArgs.builder
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiNullFieldException
import com.pulumi.kotlin.PulumiTagMarker
import kotlin.Boolean
import kotlin.Double
import kotlin.Int
import kotlin.String
import kotlin.Suppress
import kotlin.jvm.JvmName

/**
 *
 * @property balancingMode Specifies the balancing mode for this backend.
 * See the [Backend Services Overview](https://cloud.google.com/load-balancing/docs/backend-service#balancing-mode)
 * for an explanation of load balancing modes.
 * Default value is `CONNECTION`.
 * Possible values are: `UTILIZATION`, `RATE`, `CONNECTION`.
 * @property capacityScaler A multiplier applied to the group's maximum servicing capacity
 * (based on UTILIZATION, RATE or CONNECTION).
 * ~>**NOTE**: This field cannot be set for
 * INTERNAL region backend services (default loadBalancingScheme),
 * but is required for non-INTERNAL backend service. The total
 * capacity_scaler for all backends must be non-zero.
 * A setting of 0 means the group is completely drained, offering
 * 0% of its available Capacity. Valid range is [0.0,1.0].
 * @property description An optional description of this resource.
 * Provide this property when you create the resource.
 * @property failover This field designates whether this is a failover backend. More
 * than one failover backend can be configured for a given RegionBackendService.
 * @property group The fully-qualified URL of an Instance Group or Network Endpoint
 * Group resource. In case of instance group this defines the list
 * of instances that serve traffic. Member virtual machine
 * instances from each instance group must live in the same zone as
 * the instance group itself. No two backends in a backend service
 * are allowed to use same Instance Group resource.
 * For Network Endpoint Groups this defines list of endpoints. All
 * endpoints of Network Endpoint Group must be hosted on instances
 * located in the same zone as the Network Endpoint Group.
 * Backend services cannot mix Instance Group and
 * Network Endpoint Group backends.
 * When the `load_balancing_scheme` is INTERNAL, only instance groups
 * are supported.
 * Note that you must specify an Instance Group or Network Endpoint
 * Group resource using the fully-qualified URL, rather than a
 * partial URL.
 * @property maxConnections The max number of simultaneous connections for the group. Can
 * be used with either CONNECTION or UTILIZATION balancing modes.
 * Cannot be set for INTERNAL backend services.
 * For CONNECTION mode, either maxConnections or one
 * of maxConnectionsPerInstance or maxConnectionsPerEndpoint,
 * as appropriate for group type, must be set.
 * @property maxConnectionsPerEndpoint The max number of simultaneous connections that a single backend
 * network endpoint can handle. Cannot be set
 * for INTERNAL backend services.
 * This is used to calculate the capacity of the group. Can be
 * used in either CONNECTION or UTILIZATION balancing modes. For
 * CONNECTION mode, either maxConnections or
 * maxConnectionsPerEndpoint must be set.
 * @property maxConnectionsPerInstance The max number of simultaneous connections that a single
 * backend instance can handle. Cannot be set for INTERNAL backend
 * services.
 * This is used to calculate the capacity of the group.
 * Can be used in either CONNECTION or UTILIZATION balancing modes.
 * For CONNECTION mode, either maxConnections or
 * maxConnectionsPerInstance must be set.
 * @property maxRate The max requests per second (RPS) of the group. Cannot be set
 * for INTERNAL backend services.
 * Can be used with either RATE or UTILIZATION balancing modes,
 * but required if RATE mode. Either maxRate or one
 * of maxRatePerInstance or maxRatePerEndpoint, as appropriate for
 * group type, must be set.
 * @property maxRatePerEndpoint The max requests per second (RPS) that a single backend network
 * endpoint can handle. This is used to calculate the capacity of
 * the group. Can be used in either balancing mode. For RATE mode,
 * either maxRate or maxRatePerEndpoint must be set. Cannot be set
 * for INTERNAL backend services.
 * @property maxRatePerInstance The max requests per second (RPS) that a single backend
 * instance can handle. This is used to calculate the capacity of
 * the group. Can be used in either balancing mode. For RATE mode,
 * either maxRate or maxRatePerInstance must be set. Cannot be set
 * for INTERNAL backend services.
 * @property maxUtilization Used when balancingMode is UTILIZATION. This ratio defines the
 * CPU utilization target for the group. Valid range is [0.0, 1.0].
 * Cannot be set for INTERNAL backend services.
 */
public data class RegionBackendServiceBackendArgs(
    public val balancingMode: Output? = null,
    public val capacityScaler: Output? = null,
    public val description: Output? = null,
    public val failover: Output? = null,
    public val group: Output,
    public val maxConnections: Output? = null,
    public val maxConnectionsPerEndpoint: Output? = null,
    public val maxConnectionsPerInstance: Output? = null,
    public val maxRate: Output? = null,
    public val maxRatePerEndpoint: Output? = null,
    public val maxRatePerInstance: Output? = null,
    public val maxUtilization: Output? = null,
) : ConvertibleToJava {
    override fun toJava(): com.pulumi.gcp.compute.inputs.RegionBackendServiceBackendArgs =
        com.pulumi.gcp.compute.inputs.RegionBackendServiceBackendArgs.builder()
            .balancingMode(balancingMode?.applyValue({ args0 -> args0 }))
            .capacityScaler(capacityScaler?.applyValue({ args0 -> args0 }))
            .description(description?.applyValue({ args0 -> args0 }))
            .failover(failover?.applyValue({ args0 -> args0 }))
            .group(group.applyValue({ args0 -> args0 }))
            .maxConnections(maxConnections?.applyValue({ args0 -> args0 }))
            .maxConnectionsPerEndpoint(maxConnectionsPerEndpoint?.applyValue({ args0 -> args0 }))
            .maxConnectionsPerInstance(maxConnectionsPerInstance?.applyValue({ args0 -> args0 }))
            .maxRate(maxRate?.applyValue({ args0 -> args0 }))
            .maxRatePerEndpoint(maxRatePerEndpoint?.applyValue({ args0 -> args0 }))
            .maxRatePerInstance(maxRatePerInstance?.applyValue({ args0 -> args0 }))
            .maxUtilization(maxUtilization?.applyValue({ args0 -> args0 })).build()
}

/**
 * Builder for [RegionBackendServiceBackendArgs].
 */
@PulumiTagMarker
public class RegionBackendServiceBackendArgsBuilder internal constructor() {
    private var balancingMode: Output? = null

    private var capacityScaler: Output? = null

    private var description: Output? = null

    private var failover: Output? = null

    private var group: Output? = null

    private var maxConnections: Output? = null

    private var maxConnectionsPerEndpoint: Output? = null

    private var maxConnectionsPerInstance: Output? = null

    private var maxRate: Output? = null

    private var maxRatePerEndpoint: Output? = null

    private var maxRatePerInstance: Output? = null

    private var maxUtilization: Output? = null

    /**
     * @param value Specifies the balancing mode for this backend.
     * See the [Backend Services Overview](https://cloud.google.com/load-balancing/docs/backend-service#balancing-mode)
     * for an explanation of load balancing modes.
     * Default value is `CONNECTION`.
     * Possible values are: `UTILIZATION`, `RATE`, `CONNECTION`.
     */
    @JvmName("ordcmycajiqaykqc")
    public suspend fun balancingMode(`value`: Output) {
        this.balancingMode = value
    }

    /**
     * @param value A multiplier applied to the group's maximum servicing capacity
     * (based on UTILIZATION, RATE or CONNECTION).
     * ~>**NOTE**: This field cannot be set for
     * INTERNAL region backend services (default loadBalancingScheme),
     * but is required for non-INTERNAL backend service. The total
     * capacity_scaler for all backends must be non-zero.
     * A setting of 0 means the group is completely drained, offering
     * 0% of its available Capacity. Valid range is [0.0,1.0].
     */
    @JvmName("wewjhouqubxefmow")
    public suspend fun capacityScaler(`value`: Output) {
        this.capacityScaler = value
    }

    /**
     * @param value An optional description of this resource.
     * Provide this property when you create the resource.
     */
    @JvmName("cvonvyxsqposaens")
    public suspend fun description(`value`: Output) {
        this.description = value
    }

    /**
     * @param value This field designates whether this is a failover backend. More
     * than one failover backend can be configured for a given RegionBackendService.
     */
    @JvmName("wjvaxbahnycpshds")
    public suspend fun failover(`value`: Output) {
        this.failover = value
    }

    /**
     * @param value The fully-qualified URL of an Instance Group or Network Endpoint
     * Group resource. In case of instance group this defines the list
     * of instances that serve traffic. Member virtual machine
     * instances from each instance group must live in the same zone as
     * the instance group itself. No two backends in a backend service
     * are allowed to use same Instance Group resource.
     * For Network Endpoint Groups this defines list of endpoints. All
     * endpoints of Network Endpoint Group must be hosted on instances
     * located in the same zone as the Network Endpoint Group.
     * Backend services cannot mix Instance Group and
     * Network Endpoint Group backends.
     * When the `load_balancing_scheme` is INTERNAL, only instance groups
     * are supported.
     * Note that you must specify an Instance Group or Network Endpoint
     * Group resource using the fully-qualified URL, rather than a
     * partial URL.
     */
    @JvmName("hfhwuojgfrivrtwv")
    public suspend fun group(`value`: Output) {
        this.group = value
    }

    /**
     * @param value The max number of simultaneous connections for the group. Can
     * be used with either CONNECTION or UTILIZATION balancing modes.
     * Cannot be set for INTERNAL backend services.
     * For CONNECTION mode, either maxConnections or one
     * of maxConnectionsPerInstance or maxConnectionsPerEndpoint,
     * as appropriate for group type, must be set.
     */
    @JvmName("fjwfeqvhlaqtsicv")
    public suspend fun maxConnections(`value`: Output) {
        this.maxConnections = value
    }

    /**
     * @param value The max number of simultaneous connections that a single backend
     * network endpoint can handle. Cannot be set
     * for INTERNAL backend services.
     * This is used to calculate the capacity of the group. Can be
     * used in either CONNECTION or UTILIZATION balancing modes. For
     * CONNECTION mode, either maxConnections or
     * maxConnectionsPerEndpoint must be set.
     */
    @JvmName("tnmbubrljuwermjw")
    public suspend fun maxConnectionsPerEndpoint(`value`: Output) {
        this.maxConnectionsPerEndpoint = value
    }

    /**
     * @param value The max number of simultaneous connections that a single
     * backend instance can handle. Cannot be set for INTERNAL backend
     * services.
     * This is used to calculate the capacity of the group.
     * Can be used in either CONNECTION or UTILIZATION balancing modes.
     * For CONNECTION mode, either maxConnections or
     * maxConnectionsPerInstance must be set.
     */
    @JvmName("mpqwqvxhjevmeffg")
    public suspend fun maxConnectionsPerInstance(`value`: Output) {
        this.maxConnectionsPerInstance = value
    }

    /**
     * @param value The max requests per second (RPS) of the group. Cannot be set
     * for INTERNAL backend services.
     * Can be used with either RATE or UTILIZATION balancing modes,
     * but required if RATE mode. Either maxRate or one
     * of maxRatePerInstance or maxRatePerEndpoint, as appropriate for
     * group type, must be set.
     */
    @JvmName("vpsetlmvsrbuddms")
    public suspend fun maxRate(`value`: Output) {
        this.maxRate = value
    }

    /**
     * @param value The max requests per second (RPS) that a single backend network
     * endpoint can handle. This is used to calculate the capacity of
     * the group. Can be used in either balancing mode. For RATE mode,
     * either maxRate or maxRatePerEndpoint must be set. Cannot be set
     * for INTERNAL backend services.
     */
    @JvmName("prnxxydvwlygomad")
    public suspend fun maxRatePerEndpoint(`value`: Output) {
        this.maxRatePerEndpoint = value
    }

    /**
     * @param value The max requests per second (RPS) that a single backend
     * instance can handle. This is used to calculate the capacity of
     * the group. Can be used in either balancing mode. For RATE mode,
     * either maxRate or maxRatePerInstance must be set. Cannot be set
     * for INTERNAL backend services.
     */
    @JvmName("pnyshgjdatcsrown")
    public suspend fun maxRatePerInstance(`value`: Output) {
        this.maxRatePerInstance = value
    }

    /**
     * @param value Used when balancingMode is UTILIZATION. This ratio defines the
     * CPU utilization target for the group. Valid range is [0.0, 1.0].
     * Cannot be set for INTERNAL backend services.
     */
    @JvmName("wylkjqyvetdfmvbf")
    public suspend fun maxUtilization(`value`: Output) {
        this.maxUtilization = value
    }

    /**
     * @param value Specifies the balancing mode for this backend.
     * See the [Backend Services Overview](https://cloud.google.com/load-balancing/docs/backend-service#balancing-mode)
     * for an explanation of load balancing modes.
     * Default value is `CONNECTION`.
     * Possible values are: `UTILIZATION`, `RATE`, `CONNECTION`.
     */
    @JvmName("cpowexlhjghlofms")
    public suspend fun balancingMode(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.balancingMode = mapped
    }

    /**
     * @param value A multiplier applied to the group's maximum servicing capacity
     * (based on UTILIZATION, RATE or CONNECTION).
     * ~>**NOTE**: This field cannot be set for
     * INTERNAL region backend services (default loadBalancingScheme),
     * but is required for non-INTERNAL backend service. The total
     * capacity_scaler for all backends must be non-zero.
     * A setting of 0 means the group is completely drained, offering
     * 0% of its available Capacity. Valid range is [0.0,1.0].
     */
    @JvmName("jpelteuhiuislvfx")
    public suspend fun capacityScaler(`value`: Double?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.capacityScaler = mapped
    }

    /**
     * @param value An optional description of this resource.
     * Provide this property when you create the resource.
     */
    @JvmName("dodjawcyifaaruut")
    public suspend fun description(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.description = mapped
    }

    /**
     * @param value This field designates whether this is a failover backend. More
     * than one failover backend can be configured for a given RegionBackendService.
     */
    @JvmName("vmjnmaenirolrbjv")
    public suspend fun failover(`value`: Boolean?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.failover = mapped
    }

    /**
     * @param value The fully-qualified URL of an Instance Group or Network Endpoint
     * Group resource. In case of instance group this defines the list
     * of instances that serve traffic. Member virtual machine
     * instances from each instance group must live in the same zone as
     * the instance group itself. No two backends in a backend service
     * are allowed to use same Instance Group resource.
     * For Network Endpoint Groups this defines list of endpoints. All
     * endpoints of Network Endpoint Group must be hosted on instances
     * located in the same zone as the Network Endpoint Group.
     * Backend services cannot mix Instance Group and
     * Network Endpoint Group backends.
     * When the `load_balancing_scheme` is INTERNAL, only instance groups
     * are supported.
     * Note that you must specify an Instance Group or Network Endpoint
     * Group resource using the fully-qualified URL, rather than a
     * partial URL.
     */
    @JvmName("xtoiuqkhlgdvnpwj")
    public suspend fun group(`value`: String) {
        val toBeMapped = value
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.group = mapped
    }

    /**
     * @param value The max number of simultaneous connections for the group. Can
     * be used with either CONNECTION or UTILIZATION balancing modes.
     * Cannot be set for INTERNAL backend services.
     * For CONNECTION mode, either maxConnections or one
     * of maxConnectionsPerInstance or maxConnectionsPerEndpoint,
     * as appropriate for group type, must be set.
     */
    @JvmName("forhyonmpnkclowt")
    public suspend fun maxConnections(`value`: Int?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.maxConnections = mapped
    }

    /**
     * @param value The max number of simultaneous connections that a single backend
     * network endpoint can handle. Cannot be set
     * for INTERNAL backend services.
     * This is used to calculate the capacity of the group. Can be
     * used in either CONNECTION or UTILIZATION balancing modes. For
     * CONNECTION mode, either maxConnections or
     * maxConnectionsPerEndpoint must be set.
     */
    @JvmName("tkgqiqkesfkmgtcf")
    public suspend fun maxConnectionsPerEndpoint(`value`: Int?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.maxConnectionsPerEndpoint = mapped
    }

    /**
     * @param value The max number of simultaneous connections that a single
     * backend instance can handle. Cannot be set for INTERNAL backend
     * services.
     * This is used to calculate the capacity of the group.
     * Can be used in either CONNECTION or UTILIZATION balancing modes.
     * For CONNECTION mode, either maxConnections or
     * maxConnectionsPerInstance must be set.
     */
    @JvmName("luyqrpjifmwiulwt")
    public suspend fun maxConnectionsPerInstance(`value`: Int?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.maxConnectionsPerInstance = mapped
    }

    /**
     * @param value The max requests per second (RPS) of the group. Cannot be set
     * for INTERNAL backend services.
     * Can be used with either RATE or UTILIZATION balancing modes,
     * but required if RATE mode. Either maxRate or one
     * of maxRatePerInstance or maxRatePerEndpoint, as appropriate for
     * group type, must be set.
     */
    @JvmName("aswxpjrfjwhcnwgt")
    public suspend fun maxRate(`value`: Int?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.maxRate = mapped
    }

    /**
     * @param value The max requests per second (RPS) that a single backend network
     * endpoint can handle. This is used to calculate the capacity of
     * the group. Can be used in either balancing mode. For RATE mode,
     * either maxRate or maxRatePerEndpoint must be set. Cannot be set
     * for INTERNAL backend services.
     */
    @JvmName("xonwwvhlgseotwjs")
    public suspend fun maxRatePerEndpoint(`value`: Double?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.maxRatePerEndpoint = mapped
    }

    /**
     * @param value The max requests per second (RPS) that a single backend
     * instance can handle. This is used to calculate the capacity of
     * the group. Can be used in either balancing mode. For RATE mode,
     * either maxRate or maxRatePerInstance must be set. Cannot be set
     * for INTERNAL backend services.
     */
    @JvmName("aaforkarnmvunadp")
    public suspend fun maxRatePerInstance(`value`: Double?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.maxRatePerInstance = mapped
    }

    /**
     * @param value Used when balancingMode is UTILIZATION. This ratio defines the
     * CPU utilization target for the group. Valid range is [0.0, 1.0].
     * Cannot be set for INTERNAL backend services.
     */
    @JvmName("yjiusuwajyfdjupt")
    public suspend fun maxUtilization(`value`: Double?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.maxUtilization = mapped
    }

    internal fun build(): RegionBackendServiceBackendArgs = RegionBackendServiceBackendArgs(
        balancingMode = balancingMode,
        capacityScaler = capacityScaler,
        description = description,
        failover = failover,
        group = group ?: throw PulumiNullFieldException("group"),
        maxConnections = maxConnections,
        maxConnectionsPerEndpoint = maxConnectionsPerEndpoint,
        maxConnectionsPerInstance = maxConnectionsPerInstance,
        maxRate = maxRate,
        maxRatePerEndpoint = maxRatePerEndpoint,
        maxRatePerInstance = maxRatePerInstance,
        maxUtilization = maxUtilization,
    )
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy