Class OutlierDetection (1.0.0)

public sealed class OutlierDetection : IMessage<OutlierDetection>, IEquatable<OutlierDetection>, IDeepCloneable<OutlierDetection>, IBufferMessage, IMessage

Settings controlling the eviction of unhealthy hosts from the load balancing pool for the backend service.

Inheritance

Object > OutlierDetection

Namespace

Google.Cloud.Compute.V1

Assembly

Google.Cloud.Compute.V1.dll

Constructors

OutlierDetection()

public OutlierDetection()

OutlierDetection(OutlierDetection)

public OutlierDetection(OutlierDetection other)
Parameter
NameDescription
otherOutlierDetection

Properties

BaseEjectionTime

public Duration BaseEjectionTime { get; set; }

The base time that a host is ejected for. The real ejection time is equal to the base ejection time multiplied by the number of times the host has been ejected. Defaults to 30000ms or 30s.

Property Value
TypeDescription
Duration

ConsecutiveErrors

public int ConsecutiveErrors { get; set; }

Number of errors before a host is ejected from the connection pool. When the backend host is accessed over HTTP, a 5xx return code qualifies as an error. Defaults to 5.

Property Value
TypeDescription
Int32

ConsecutiveGatewayFailure

public int ConsecutiveGatewayFailure { get; set; }

The number of consecutive gateway failures (502, 503, 504 status or connection errors that are mapped to one of those status codes) before a consecutive gateway failure ejection occurs. Defaults to 3.

Property Value
TypeDescription
Int32

EnforcingConsecutiveErrors

public int EnforcingConsecutiveErrors { get; set; }

The percentage chance that a host will be actually ejected when an outlier status is detected through consecutive 5xx. This setting can be used to disable ejection or to ramp it up slowly. Defaults to 0.

Property Value
TypeDescription
Int32

EnforcingConsecutiveGatewayFailure

public int EnforcingConsecutiveGatewayFailure { get; set; }

The percentage chance that a host will be actually ejected when an outlier status is detected through consecutive gateway failures. This setting can be used to disable ejection or to ramp it up slowly. Defaults to 100.

Property Value
TypeDescription
Int32

EnforcingSuccessRate

public int EnforcingSuccessRate { get; set; }

The percentage chance that a host will be actually ejected when an outlier status is detected through success rate statistics. This setting can be used to disable ejection or to ramp it up slowly. Defaults to 100.

Property Value
TypeDescription
Int32

HasConsecutiveErrors

public bool HasConsecutiveErrors { get; }

Gets whether the "consecutive_errors" field is set

Property Value
TypeDescription
Boolean

HasConsecutiveGatewayFailure

public bool HasConsecutiveGatewayFailure { get; }

Gets whether the "consecutive_gateway_failure" field is set

Property Value
TypeDescription
Boolean

HasEnforcingConsecutiveErrors

public bool HasEnforcingConsecutiveErrors { get; }

Gets whether the "enforcing_consecutive_errors" field is set

Property Value
TypeDescription
Boolean

HasEnforcingConsecutiveGatewayFailure

public bool HasEnforcingConsecutiveGatewayFailure { get; }

Gets whether the "enforcing_consecutive_gateway_failure" field is set

Property Value
TypeDescription
Boolean

HasEnforcingSuccessRate

public bool HasEnforcingSuccessRate { get; }

Gets whether the "enforcing_success_rate" field is set

Property Value
TypeDescription
Boolean

HasMaxEjectionPercent

public bool HasMaxEjectionPercent { get; }

Gets whether the "max_ejection_percent" field is set

Property Value
TypeDescription
Boolean

HasSuccessRateMinimumHosts

public bool HasSuccessRateMinimumHosts { get; }

Gets whether the "success_rate_minimum_hosts" field is set

Property Value
TypeDescription
Boolean

HasSuccessRateRequestVolume

public bool HasSuccessRateRequestVolume { get; }

Gets whether the "success_rate_request_volume" field is set

Property Value
TypeDescription
Boolean

HasSuccessRateStdevFactor

public bool HasSuccessRateStdevFactor { get; }

Gets whether the "success_rate_stdev_factor" field is set

Property Value
TypeDescription
Boolean

Interval

public Duration Interval { get; set; }

Time interval between ejection analysis sweeps. This can result in both new ejections as well as hosts being returned to service. Defaults to 1 second.

Property Value
TypeDescription
Duration

MaxEjectionPercent

public int MaxEjectionPercent { get; set; }

Maximum percentage of hosts in the load balancing pool for the backend service that can be ejected. Defaults to 50%.

Property Value
TypeDescription
Int32

SuccessRateMinimumHosts

public int SuccessRateMinimumHosts { get; set; }

The number of hosts in a cluster that must have enough request volume to detect success rate outliers. If the number of hosts is less than this setting, outlier detection via success rate statistics is not performed for any host in the cluster. Defaults to 5.

Property Value
TypeDescription
Int32

SuccessRateRequestVolume

public int SuccessRateRequestVolume { get; set; }

The minimum number of total requests that must be collected in one interval (as defined by the interval duration above) to include this host in success rate based outlier detection. If the volume is lower than this setting, outlier detection via success rate statistics is not performed for that host. Defaults to 100.

Property Value
TypeDescription
Int32

SuccessRateStdevFactor

public int SuccessRateStdevFactor { get; set; }

This factor is used to determine the ejection threshold for success rate outlier ejection. The ejection threshold is the difference between the mean success rate, and the product of this factor and the standard deviation of the mean success rate: mean - (stdev * success_rate_stdev_factor). This factor is divided by a thousand to get a double. That is, if the desired factor is 1.9, the runtime value should be 1900. Defaults to 1900.

Property Value
TypeDescription
Int32