com.pulumi.kubernetes.flowcontrol.v1beta3.outputs.ExemptPriorityLevelConfiguration Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of kubernetes Show documentation
Show all versions of kubernetes Show documentation
A Pulumi package for creating and managing Kubernetes resources.
// *** WARNING: this file was generated by pulumi-java-gen. ***
// *** Do not edit by hand unless you're certain you know what you are doing! ***
package com.pulumi.kubernetes.flowcontrol.v1beta3.outputs;
import com.pulumi.core.annotations.CustomType;
import java.lang.Integer;
import java.util.Objects;
import java.util.Optional;
import javax.annotation.Nullable;
@CustomType
public final class ExemptPriorityLevelConfiguration {
/**
* @return `lendablePercent` prescribes the fraction of the level's NominalCL that can be borrowed by other priority levels. This value of this field must be between 0 and 100, inclusive, and it defaults to 0. The number of seats that other levels can borrow from this level, known as this level's LendableConcurrencyLimit (LendableCL), is defined as follows.
*
* LendableCL(i) = round( NominalCL(i) * lendablePercent(i)/100.0 )
*
*/
private @Nullable Integer lendablePercent;
/**
* @return `nominalConcurrencyShares` (NCS) contributes to the computation of the NominalConcurrencyLimit (NominalCL) of this level. This is the number of execution seats nominally reserved for this priority level. This DOES NOT limit the dispatching from this priority level but affects the other priority levels through the borrowing mechanism. The server's concurrency limit (ServerCL) is divided among all the priority levels in proportion to their NCS values:
*
* NominalCL(i) = ceil( ServerCL * NCS(i) / sum_ncs ) sum_ncs = sum[priority level k] NCS(k)
*
* Bigger numbers mean a larger nominal concurrency limit, at the expense of every other priority level. This field has a default value of zero.
*
*/
private @Nullable Integer nominalConcurrencyShares;
private ExemptPriorityLevelConfiguration() {}
/**
* @return `lendablePercent` prescribes the fraction of the level's NominalCL that can be borrowed by other priority levels. This value of this field must be between 0 and 100, inclusive, and it defaults to 0. The number of seats that other levels can borrow from this level, known as this level's LendableConcurrencyLimit (LendableCL), is defined as follows.
*
* LendableCL(i) = round( NominalCL(i) * lendablePercent(i)/100.0 )
*
*/
public Optional lendablePercent() {
return Optional.ofNullable(this.lendablePercent);
}
/**
* @return `nominalConcurrencyShares` (NCS) contributes to the computation of the NominalConcurrencyLimit (NominalCL) of this level. This is the number of execution seats nominally reserved for this priority level. This DOES NOT limit the dispatching from this priority level but affects the other priority levels through the borrowing mechanism. The server's concurrency limit (ServerCL) is divided among all the priority levels in proportion to their NCS values:
*
* NominalCL(i) = ceil( ServerCL * NCS(i) / sum_ncs ) sum_ncs = sum[priority level k] NCS(k)
*
* Bigger numbers mean a larger nominal concurrency limit, at the expense of every other priority level. This field has a default value of zero.
*
*/
public Optional nominalConcurrencyShares() {
return Optional.ofNullable(this.nominalConcurrencyShares);
}
public static Builder builder() {
return new Builder();
}
public static Builder builder(ExemptPriorityLevelConfiguration defaults) {
return new Builder(defaults);
}
@CustomType.Builder
public static final class Builder {
private @Nullable Integer lendablePercent;
private @Nullable Integer nominalConcurrencyShares;
public Builder() {}
public Builder(ExemptPriorityLevelConfiguration defaults) {
Objects.requireNonNull(defaults);
this.lendablePercent = defaults.lendablePercent;
this.nominalConcurrencyShares = defaults.nominalConcurrencyShares;
}
@CustomType.Setter
public Builder lendablePercent(@Nullable Integer lendablePercent) {
this.lendablePercent = lendablePercent;
return this;
}
@CustomType.Setter
public Builder nominalConcurrencyShares(@Nullable Integer nominalConcurrencyShares) {
this.nominalConcurrencyShares = nominalConcurrencyShares;
return this;
}
public ExemptPriorityLevelConfiguration build() {
final var _resultValue = new ExemptPriorityLevelConfiguration();
_resultValue.lendablePercent = lendablePercent;
_resultValue.nominalConcurrencyShares = nominalConcurrencyShares;
return _resultValue;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy