Class: Google::Apis::FileV1::GoogleCloudSaasacceleratorManagementProvidersV1SloMetadata

Inherits:
Object
  • Object
show all
Includes:
Core::Hashable, Core::JsonObjectSupport
Defined in:
lib/google/apis/file_v1/classes.rb,
lib/google/apis/file_v1/representations.rb,
lib/google/apis/file_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.



741
742
743
# File 'lib/google/apis/file_v1/classes.rb', line 741

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

Instance Attribute Details

#eligibilityGoogle::Apis::FileV1::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



705
706
707
# File 'lib/google/apis/file_v1/classes.rb', line 705

def eligibility
  @eligibility
end

#exclusionsArray<Google::Apis::FileV1::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



719
720
721
# File 'lib/google/apis/file_v1/classes.rb', line 719

def exclusions
  @exclusions
end

#nodesArray<Google::Apis::FileV1::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



727
728
729
# File 'lib/google/apis/file_v1/classes.rb', line 727

def nodes
  @nodes
end

#per_sli_eligibilityGoogle::Apis::FileV1::GoogleCloudSaasacceleratorManagementProvidersV1PerSliSloEligibility

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



732
733
734
# File 'lib/google/apis/file_v1/classes.rb', line 732

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)


739
740
741
# File 'lib/google/apis/file_v1/classes.rb', line 739

def tier
  @tier
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



746
747
748
749
750
751
752
# File 'lib/google/apis/file_v1/classes.rb', line 746

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