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

com.pulumi.gcp.compute.kotlin.outputs.RegionBackendServiceBackend.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.Boolean
import kotlin.Double
import kotlin.Int
import kotlin.String
import kotlin.Suppress

/**
 *
 * @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 RegionBackendServiceBackend(
    public val balancingMode: String? = null,
    public val capacityScaler: Double? = null,
    public val description: String? = null,
    public val failover: Boolean? = null,
    public val group: String,
    public val maxConnections: Int? = null,
    public val maxConnectionsPerEndpoint: Int? = null,
    public val maxConnectionsPerInstance: Int? = null,
    public val maxRate: Int? = null,
    public val maxRatePerEndpoint: Double? = null,
    public val maxRatePerInstance: Double? = null,
    public val maxUtilization: Double? = null,
) {
    public companion object {
        public fun toKotlin(javaType: com.pulumi.gcp.compute.outputs.RegionBackendServiceBackend): RegionBackendServiceBackend = RegionBackendServiceBackend(
            balancingMode = javaType.balancingMode().map({ args0 -> args0 }).orElse(null),
            capacityScaler = javaType.capacityScaler().map({ args0 -> args0 }).orElse(null),
            description = javaType.description().map({ args0 -> args0 }).orElse(null),
            failover = javaType.failover().map({ args0 -> args0 }).orElse(null),
            group = javaType.group(),
            maxConnections = javaType.maxConnections().map({ args0 -> args0 }).orElse(null),
            maxConnectionsPerEndpoint = javaType.maxConnectionsPerEndpoint().map({ args0 ->
                args0
            }).orElse(null),
            maxConnectionsPerInstance = javaType.maxConnectionsPerInstance().map({ args0 ->
                args0
            }).orElse(null),
            maxRate = javaType.maxRate().map({ args0 -> args0 }).orElse(null),
            maxRatePerEndpoint = javaType.maxRatePerEndpoint().map({ args0 -> args0 }).orElse(null),
            maxRatePerInstance = javaType.maxRatePerInstance().map({ args0 -> args0 }).orElse(null),
            maxUtilization = javaType.maxUtilization().map({ args0 -> args0 }).orElse(null),
        )
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy