Class: Google::Apis::ComputeAlpha::BackendServiceConnectionTrackingPolicy

Inherits:
Object
  • Object
show all
Includes:
Google::Apis::Core::Hashable, Google::Apis::Core::JsonObjectSupport
Defined in:
lib/google/apis/compute_alpha/classes.rb,
lib/google/apis/compute_alpha/representations.rb,
lib/google/apis/compute_alpha/representations.rb

Overview

Connection Tracking configuration for this BackendService.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ BackendServiceConnectionTrackingPolicy

Returns a new instance of BackendServiceConnectionTrackingPolicy.



4292
4293
4294
# File 'lib/google/apis/compute_alpha/classes.rb', line 4292

def initialize(**args)
   update!(**args)
end

Instance Attribute Details

#connection_persistence_on_unhealthy_backendsString

Specifies connection persistence when backends are unhealthy. The default value is DEFAULT_FOR_PROTOCOL. If set to DEFAULT_FOR_PROTOCOL, the existing connections persist on unhealthy backends only for connection-oriented protocols (TCP and SCTP) and only if the Tracking Mode is PER_CONNECTION ( default tracking mode) or the Session Affinity is configured for 5-tuple. They do not persist for UDP. If set to NEVER_PERSIST, after a backend becomes unhealthy, the existing connections on the unhealthy backend are never persisted on the unhealthy backend. They are always diverted to newly selected healthy backends (unless all backends are unhealthy). If set to ALWAYS_PERSIST, existing connections always persist on unhealthy backends regardless of protocol and session affinity. It is generally not recommended to use this mode overriding the default. For more details, see Connection Persistence for Network Load Balancing and Connection Persistence for Internal TCP/UDP Load Balancing. Corresponds to the JSON property connectionPersistenceOnUnhealthyBackends

Returns:

  • (String)


4259
4260
4261
# File 'lib/google/apis/compute_alpha/classes.rb', line 4259

def connection_persistence_on_unhealthy_backends
  @connection_persistence_on_unhealthy_backends
end

#enable_strong_affinityBoolean Also known as: enable_strong_affinity?

Enable Strong Session Affinity for Network Load Balancing. This option is not available publicly. Corresponds to the JSON property enableStrongAffinity

Returns:

  • (Boolean)


4265
4266
4267
# File 'lib/google/apis/compute_alpha/classes.rb', line 4265

def enable_strong_affinity
  @enable_strong_affinity
end

#idle_timeout_secFixnum

Specifies how long to keep a Connection Tracking entry while there is no matching traffic (in seconds). For Internal TCP/UDP Load Balancing: - The minimum (default) is 10 minutes and the maximum is 16 hours. - It can be set only if Connection Tracking is less than 5-tuple (i.e. Session Affinity is CLIENT_IP_NO_DESTINATION, CLIENT_IP or CLIENT_IP_PROTO, and Tracking Mode is PER_SESSION). For Network Load Balancer the default is 60 seconds. This option is not available publicly. Corresponds to the JSON property idleTimeoutSec

Returns:

  • (Fixnum)


4277
4278
4279
# File 'lib/google/apis/compute_alpha/classes.rb', line 4277

def idle_timeout_sec
  @idle_timeout_sec
end

#tracking_modeString

Specifies the key used for connection tracking. There are two options: - PER_CONNECTION: This is the default mode. The Connection Tracking is performed as per the Connection Key (default Hash Method) for the specific protocol. - PER_SESSION: The Connection Tracking is performed as per the configured Session Affinity. It matches the configured Session Affinity. For more details, see Tracking Mode for Network Load Balancing and Tracking Mode for Internal TCP/UDP Load Balancing. Corresponds to the JSON property trackingMode

Returns:

  • (String)


4290
4291
4292
# File 'lib/google/apis/compute_alpha/classes.rb', line 4290

def tracking_mode
  @tracking_mode
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



4297
4298
4299
4300
4301
4302
# File 'lib/google/apis/compute_alpha/classes.rb', line 4297

def update!(**args)
  @connection_persistence_on_unhealthy_backends = args[:connection_persistence_on_unhealthy_backends] if args.key?(:connection_persistence_on_unhealthy_backends)
  @enable_strong_affinity = args[:enable_strong_affinity] if args.key?(:enable_strong_affinity)
  @idle_timeout_sec = args[:idle_timeout_sec] if args.key?(:idle_timeout_sec)
  @tracking_mode = args[:tracking_mode] if args.key?(:tracking_mode)
end