Class: Google::Apis::ManagedidentitiesV1alpha1::GoogleCloudSaasacceleratorManagementProvidersV1SloMetadata

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



990
991
992
# File 'generated/google/apis/managedidentities_v1alpha1/classes.rb', line 990

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

Instance Attribute Details

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



959
960
961
# File 'generated/google/apis/managedidentities_v1alpha1/classes.rb', line 959

def eligibility
  @eligibility
end

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



973
974
975
# File 'generated/google/apis/managedidentities_v1alpha1/classes.rb', line 973

def exclusions
  @exclusions
end

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



981
982
983
# File 'generated/google/apis/managedidentities_v1alpha1/classes.rb', line 981

def nodes
  @nodes
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)


988
989
990
# File 'generated/google/apis/managedidentities_v1alpha1/classes.rb', line 988

def tier
  @tier
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



995
996
997
998
999
1000
# File 'generated/google/apis/managedidentities_v1alpha1/classes.rb', line 995

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