Class ServiceLevelObjective
- All Implemented Interfaces:
Serializable
,SdkPojo
,ToCopyableBuilder<ServiceLevelObjective.Builder,
ServiceLevelObjective>
A structure containing information about one service level objective (SLO) that has been created in Application Signals. Creating SLOs can help you ensure your services are performing to the level that you expect. SLOs help you set and track a specific target level for the reliability and availability of your applications and services. Each SLO uses a service level indicator (SLI), which is a key performance metric, to calculate how much underperformance can be tolerated before the goal that you set for the SLO is not achieved.
- See Also:
-
Nested Class Summary
Nested Classes -
Method Summary
Modifier and TypeMethodDescriptionfinal String
arn()
The ARN of this SLO.builder()
final List
<BurnRateConfiguration> Each object in this array defines the length of the look-back window used to calculate one burn rate metric for this SLO.final Instant
The date and time that this SLO was created.final String
The description that you created for this SLO.final boolean
final boolean
equalsBySdkFields
(Object obj) Indicates whether some other object is "equal to" this one by SDK fields.final EvaluationType
Displays whether this is a period-based SLO or a request-based SLO.final String
Displays whether this is a period-based SLO or a request-based SLO.final <T> Optional
<T> getValueForField
(String fieldName, Class<T> clazz) final Goal
goal()
Returns the value of the Goal property for this object.final boolean
For responses, this returns true if the service returned a value for the BurnRateConfigurations property.final int
hashCode()
final Instant
The time that this SLO was most recently updated.final MetricSourceType
Displays the SLI metric source type for this SLO.final String
Displays the SLI metric source type for this SLO.final String
name()
The name of this SLO.A structure containing information about the performance metric that this SLO monitors, if this is a request-based SLO.static Class
<? extends ServiceLevelObjective.Builder> final ServiceLevelIndicator
sli()
A structure containing information about the performance metric that this SLO monitors, if this is a period-based SLO.Take this object and create a builder that contains all of the current property values of this object.final String
toString()
Returns a string representation of this object.Methods inherited from interface software.amazon.awssdk.utils.builder.ToCopyableBuilder
copy
-
Method Details
-
arn
-
name
-
description
The description that you created for this SLO.
- Returns:
- The description that you created for this SLO.
-
createdTime
The date and time that this SLO was created. When used in a raw HTTP Query API, it is formatted as
yyyy-MM-dd'T'HH:mm:ss
. For example,2019-07-01T23:59:59
.- Returns:
- The date and time that this SLO was created. When used in a raw HTTP Query API, it is formatted as
yyyy-MM-dd'T'HH:mm:ss
. For example,2019-07-01T23:59:59
.
-
lastUpdatedTime
The time that this SLO was most recently updated. When used in a raw HTTP Query API, it is formatted as
yyyy-MM-dd'T'HH:mm:ss
. For example,2019-07-01T23:59:59
.- Returns:
- The time that this SLO was most recently updated. When used in a raw HTTP Query API, it is formatted as
yyyy-MM-dd'T'HH:mm:ss
. For example,2019-07-01T23:59:59
.
-
sli
A structure containing information about the performance metric that this SLO monitors, if this is a period-based SLO.
- Returns:
- A structure containing information about the performance metric that this SLO monitors, if this is a period-based SLO.
-
requestBasedSli
A structure containing information about the performance metric that this SLO monitors, if this is a request-based SLO.
- Returns:
- A structure containing information about the performance metric that this SLO monitors, if this is a request-based SLO.
-
evaluationType
Displays whether this is a period-based SLO or a request-based SLO.
If the service returns an enum value that is not available in the current SDK version,
evaluationType
will returnEvaluationType.UNKNOWN_TO_SDK_VERSION
. The raw value returned by the service is available fromevaluationTypeAsString()
.- Returns:
- Displays whether this is a period-based SLO or a request-based SLO.
- See Also:
-
evaluationTypeAsString
Displays whether this is a period-based SLO or a request-based SLO.
If the service returns an enum value that is not available in the current SDK version,
evaluationType
will returnEvaluationType.UNKNOWN_TO_SDK_VERSION
. The raw value returned by the service is available fromevaluationTypeAsString()
.- Returns:
- Displays whether this is a period-based SLO or a request-based SLO.
- See Also:
-
goal
Returns the value of the Goal property for this object.- Returns:
- The value of the Goal property for this object.
-
hasBurnRateConfigurations
public final boolean hasBurnRateConfigurations()For responses, this returns true if the service returned a value for the BurnRateConfigurations property. This DOES NOT check that the value is non-empty (for which, you should check theisEmpty()
method on the property). This is useful because the SDK will never return a null collection or map, but you may need to differentiate between the service returning nothing (or null) and the service returning an empty collection or map. For requests, this returns true if a value for the property was specified in the request builder, and false if a value was not specified. -
burnRateConfigurations
Each object in this array defines the length of the look-back window used to calculate one burn rate metric for this SLO. The burn rate measures how fast the service is consuming the error budget, relative to the attainment goal of the SLO.
Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
This method will never return null. If you would like to know whether the service returned this field (so that you can differentiate between null and empty), you can use the
hasBurnRateConfigurations()
method.- Returns:
- Each object in this array defines the length of the look-back window used to calculate one burn rate metric for this SLO. The burn rate measures how fast the service is consuming the error budget, relative to the attainment goal of the SLO.
-
metricSourceType
Displays the SLI metric source type for this SLO. Supported types are:
-
Service operation
-
Service dependency
-
CloudWatch metric
If the service returns an enum value that is not available in the current SDK version,
metricSourceType
will returnMetricSourceType.UNKNOWN_TO_SDK_VERSION
. The raw value returned by the service is available frommetricSourceTypeAsString()
.- Returns:
- Displays the SLI metric source type for this SLO. Supported types are:
-
Service operation
-
Service dependency
-
CloudWatch metric
-
- See Also:
-
-
metricSourceTypeAsString
Displays the SLI metric source type for this SLO. Supported types are:
-
Service operation
-
Service dependency
-
CloudWatch metric
If the service returns an enum value that is not available in the current SDK version,
metricSourceType
will returnMetricSourceType.UNKNOWN_TO_SDK_VERSION
. The raw value returned by the service is available frommetricSourceTypeAsString()
.- Returns:
- Displays the SLI metric source type for this SLO. Supported types are:
-
Service operation
-
Service dependency
-
CloudWatch metric
-
- See Also:
-
-
toBuilder
Description copied from interface:ToCopyableBuilder
Take this object and create a builder that contains all of the current property values of this object.- Specified by:
toBuilder
in interfaceToCopyableBuilder<ServiceLevelObjective.Builder,
ServiceLevelObjective> - Returns:
- a builder for type T
-
builder
-
serializableBuilderClass
-
hashCode
-
equals
-
equalsBySdkFields
Description copied from interface:SdkPojo
Indicates whether some other object is "equal to" this one by SDK fields. An SDK field is a modeled, non-inherited field in anSdkPojo
class, and is generated based on a service model.If an
SdkPojo
class does not have any inherited fields,equalsBySdkFields
andequals
are essentially the same.- Specified by:
equalsBySdkFields
in interfaceSdkPojo
- Parameters:
obj
- the object to be compared with- Returns:
- true if the other object equals to this object by sdk fields, false otherwise.
-
toString
-
getValueForField
-
sdkFields
-
sdkFieldNameToField
- Specified by:
sdkFieldNameToField
in interfaceSdkPojo
- Returns:
- The mapping between the field name and its corresponding field.
-