Class: Google::Apis::MemcacheV1::GoogleCloudSaasacceleratorManagementProvidersV1SloMetadata

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

Overview

SloMetadata contains resources required for proper SLO classification of the instance.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ GoogleCloudSaasacceleratorManagementProvidersV1SloMetadata

Returns a new instance of GoogleCloudSaasacceleratorManagementProvidersV1SloMetadata.



724
725
726
# File 'lib/google/apis/memcache_v1/classes.rb', line 724

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

Instance Attribute Details

#eligibilityGoogle::Apis::MemcacheV1::GoogleCloudSaasacceleratorManagementProvidersV1SloEligibility

SloEligibility is a tuple containing eligibility value: true if an instance is eligible for SLO calculation or false if it should be excluded from all SLO- related calculations along with a user-defined reason. Corresponds to the JSON property eligibility



688
689
690
# File 'lib/google/apis/memcache_v1/classes.rb', line 688

def eligibility
  @eligibility
end

#exclusionsArray<Google::Apis::MemcacheV1::GoogleCloudSaasacceleratorManagementProvidersV1SloExclusion>

List of SLO exclusion windows. When multiple entries in the list match ( matching the exclusion time-window against current time point) the exclusion reason used in the first matching entry will be published. It is not needed to include expired exclusion in this list, as only the currently applicable exclusions are taken into account by the eligibility exporting subsystem (the historical state of exclusions will be reflected in the historically produced timeseries regardless of the current state). This field can be used to mark the instance as temporary ineligible for the purpose of SLO calculation. For permanent instance SLO exclusion, use of custom instance eligibility is recommended. See 'eligibility' field below. Corresponds to the JSON property exclusions



702
703
704
# File 'lib/google/apis/memcache_v1/classes.rb', line 702

def exclusions
  @exclusions
end

#nodesArray<Google::Apis::MemcacheV1::GoogleCloudSaasacceleratorManagementProvidersV1NodeSloMetadata>

Optional. List of nodes. Some producers need to use per-node metadata to calculate SLO. This field allows such producers to publish per-node SLO meta data, which will be consumed by SSA Eligibility Exporter and published in the form of per node metric to Monarch. Corresponds to the JSON property nodes



710
711
712
# File 'lib/google/apis/memcache_v1/classes.rb', line 710

def nodes
  @nodes
end

#per_sli_eligibilityGoogle::Apis::MemcacheV1::GoogleCloudSaasacceleratorManagementProvidersV1PerSliSloEligibility

PerSliSloEligibility is a mapping from an SLI name to eligibility. Corresponds to the JSON property perSliEligibility



715
716
717
# File 'lib/google/apis/memcache_v1/classes.rb', line 715

def per_sli_eligibility
  @per_sli_eligibility
end

#tierString

Name of the SLO tier the Instance belongs to. This name will be expected to match the tiers specified in the service SLO configuration. Field is mandatory and must not be empty. Corresponds to the JSON property tier

Returns:

  • (String)


722
723
724
# File 'lib/google/apis/memcache_v1/classes.rb', line 722

def tier
  @tier
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



729
730
731
732
733
734
735
# File 'lib/google/apis/memcache_v1/classes.rb', line 729

def update!(**args)
  @eligibility = args[:eligibility] if args.key?(:eligibility)
  @exclusions = args[:exclusions] if args.key?(:exclusions)
  @nodes = args[:nodes] if args.key?(:nodes)
  @per_sli_eligibility = args[:per_sli_eligibility] if args.key?(:per_sli_eligibility)
  @tier = args[:tier] if args.key?(:tier)
end