REST Resource: services.serviceLevelObjectives Stay organized with collections Save and categorize content based on your preferences.
- Resource: ServiceLevelObjective
- ServiceLevelIndicator
- BasicSli
- AvailabilityCriteria
- LatencyCriteria
- RequestBasedSli
- TimeSeriesRatio
- DistributionCut
- Range
- WindowsBasedSli
- PerformanceThreshold
- MetricRange
- CalendarPeriod
- Methods
Resource: ServiceLevelObjective
A Service-Level Objective (SLO) describes a level of desired good service. It consists of a service-level indicator (SLI), a performance goal, and a period over which the objective is to be evaluated against that goal. The SLO can use SLIs defined in a number of different manners. Typical SLOs might include "99% of requests in each rolling week have latency below 200 milliseconds" or "99.5% of requests in each calendar month return successfully."
| JSON representation |
|---|
{"name":string,"displayName":string,"serviceLevelIndicator":{object ( |
| Fields | |
|---|---|
name |
Identifier. Resource name for this |
displayName |
Name used for UI elements listing this SLO. |
serviceLevelIndicator |
The definition of good service, used to measure and calculate the quality of the |
goal |
The fraction of service that must be good in order for this objective to be met. |
userLabels |
Labels which have been used to annotate the service-level objective. Label keys must start with a letter. Label keys and values may contain lowercase letters, numbers, underscores, and dashes. Label keys and values have a maximum length of 63 characters, and must be less than 128 bytes in size. Up to 64 label entries may be stored. For labels which do not have a semantic value, the empty string may be supplied for the label value. |
Union fieldperiod. The time period over which the objective will be evaluated.period can be only one of the following: | |
rollingPeriod |
A rolling time period, semantically "in the past |
calendarPeriod |
A calendar period, semantically "since the start of the current |
ServiceLevelIndicator
A Service-Level Indicator (SLI) describes the "performance" of a service. For some services, the SLI is well-defined. In such cases, the SLI can be described easily by referencing the well-known SLI and providing the needed parameters. Alternatively, a "custom" SLI can be defined with a query to the underlying metric store. An SLI is defined to begood_service / total_service over any queried time interval. The value of performance always falls into the range0 <= performance <= 1. A custom SLI describes how to compute this ratio, whether this is by dividing values from a pair of time series, cutting aDistribution into good and bad counts, or counting time windows in which the service complies with a criterion. For separation of concerns, a single Service-Level Indicator measures performance for only one aspect of service quality, such as fraction of successful queries or fast-enough queries.
| JSON representation |
|---|
{// Union field |
| Fields | |
|---|---|
Union fieldtype. Service level indicators can be grouped by whether the "unit" of service being measured is based on counts of good requests or on counts of good time windowstype can be only one of the following: | |
basicSli |
Basic SLI on a well-known service type. |
requestBased |
Request-based SLIs |
windowsBased |
Windows-based SLIs |
BasicSli
An SLI measuring performance on a well-known service type. Performance will be computed on the basis of pre-defined metrics. The type of theservice_resource determines the metrics to use and theservice_resource.labels andmetricLabels are used to construct a monitoring filter to filter that metric down to just the data relevant to this service.
| JSON representation |
|---|
{"method":[string],"location":[string],"version":[string],// Union field |
| Fields | |
|---|---|
method[] |
OPTIONAL: The set of RPCs to which this SLI is relevant. Telemetry from other methods will not be used to calculate performance for this SLI. If omitted, this SLI applies to all the Service's methods. For service types that don't support breaking down by method, setting this field will result in an error. |
location[] |
OPTIONAL: The set of locations to which this SLI is relevant. Telemetry from other locations will not be used to calculate performance for this SLI. If omitted, this SLI applies to all locations in which the Service has activity. For service types that don't support breaking down by location, setting this field will result in an error. |
version[] |
OPTIONAL: The set of API versions to which this SLI is relevant. Telemetry from other API versions will not be used to calculate performance for this SLI. If omitted, this SLI applies to all API versions. For service types that don't support breaking down by version, setting this field will result in an error. |
Union fieldsli_criteria. This SLI can be evaluated on the basis of availability or latency.sli_criteria can be only one of the following: | |
availability |
Good service is defined to be the count of requests made to this service that return successfully. |
latency |
Good service is defined to be the count of requests made to this service that are fast enough with respect to |
AvailabilityCriteria
This type has no fields.
Future parameters for the availability SLI.
LatencyCriteria
Parameters for a latency threshold SLI.
| JSON representation |
|---|
{"threshold":string} |
| Fields | |
|---|---|
threshold |
Good service is defined to be the count of requests made to this service that return in no more than |
RequestBasedSli
Service Level Indicators for which atomic units of service are counted directly.
| JSON representation |
|---|
{// Union field |
| Fields | |
|---|---|
Union fieldmethod. The means to compute a ratio ofgood_service tototal_service.method can be only one of the following: | |
goodTotalRatio |
|
distributionCut |
|
TimeSeriesRatio
ATimeSeriesRatio specifies twoTimeSeries to use for computing thegood_service / total_service ratio. The specifiedTimeSeries must haveValueType = DOUBLE orValueType = INT64 and must haveMetricKind = DELTA orMetricKind = CUMULATIVE. TheTimeSeriesRatio must specify exactly two of good, bad, and total, and the relationshipgood_service + bad_service = total_service will be assumed.
| JSON representation |
|---|
{"goodServiceFilter":string,"badServiceFilter":string,"totalServiceFilter":string} |
| Fields | |
|---|---|
goodServiceFilter |
Amonitoring filter specifying a |
badServiceFilter |
Amonitoring filter specifying a |
totalServiceFilter |
Amonitoring filter specifying a |
DistributionCut
ADistributionCut defines aTimeSeries and thresholds used for measuring good service and total service. TheTimeSeries must haveValueType = DISTRIBUTION andMetricKind = DELTA orMetricKind = CUMULATIVE. The computedgood_service will be the estimated count of values in theDistribution that fall within the specifiedmin andmax.
| JSON representation |
|---|
{"distributionFilter":string,"range":{object ( |
| Fields | |
|---|---|
distributionFilter |
Amonitoring filter specifying a |
range |
Range of values considered "good." For a one-sided range, set one bound to an infinite value. |
Range
Range of numerical values withinmin andmax.
| JSON representation |
|---|
{"min":number,"max":number} |
| Fields | |
|---|---|
min |
Range minimum. |
max |
Range maximum. |
WindowsBasedSli
AWindowsBasedSli definesgood_service as the count of time windows for which the provided service was of good quality. Criteria for determining if service was good are embedded in thewindow_criterion.
| JSON representation |
|---|
{"windowPeriod":string,// Union field |
| Fields | |
|---|---|
windowPeriod |
Duration over which window quality is evaluated. Must be an integer fraction of a day and at least |
Union fieldwindow_criterion. The criterion to use for evaluating window goodness.window_criterion can be only one of the following: | |
goodBadMetricFilter |
Amonitoring filter specifying a |
goodTotalRatioThreshold |
A window is good if its |
metricMeanInRange |
A window is good if the metric's value is in a good range, averaged across returned streams. |
metricSumInRange |
A window is good if the metric's value is in a good range, summed across returned streams. |
PerformanceThreshold
APerformanceThreshold is used when each window is good when that window has a sufficiently highperformance.
| JSON representation |
|---|
{"threshold":number,// Union field |
| Fields | |
|---|---|
threshold |
If window |
Union fieldtype. The means, either a request-based SLI or a basic SLI, by which to compute performance over a window.type can be only one of the following: | |
performance |
|
basicSliPerformance |
|
MetricRange
AMetricRange is used when each window is good when the value x of a singleTimeSeries satisfiesrange.min <= x <= range.max. The providedTimeSeries must haveValueType = INT64 orValueType = DOUBLE andMetricKind = GAUGE.
| JSON representation |
|---|
{"timeSeries":string,"range":{object ( |
| Fields | |
|---|---|
timeSeries |
Amonitoring filter specifying the |
range |
Range of values considered "good." For a one-sided range, set one bound to an infinite value. |
CalendarPeriod
ACalendarPeriod represents the abstract concept of a time period that has a canonical start. Grammatically, "the start of the currentCalendarPeriod." All calendar times begin at midnight UTC.
| Enums | |
|---|---|
CALENDAR_PERIOD_UNSPECIFIED | Undefined period, raises an error. |
DAY | A day. |
WEEK | A week. Weeks begin on Monday, followingISO 8601. |
FORTNIGHT | A fortnight. The first calendar fortnight of the year begins at the start of week 1 according toISO 8601. |
MONTH | A month. |
QUARTER | A quarter. Quarters start on dates 1-Jan, 1-Apr, 1-Jul, and 1-Oct of each year. |
HALF | A half-year. Half-years start on dates 1-Jan and 1-Jul. |
YEAR | A year. |
Methods | |
|---|---|
| Create aServiceLevelObjective for the givenService. |
| Delete the givenServiceLevelObjective. |
| Get aServiceLevelObjective by name. |
| List theServiceLevelObjectives for the givenService. |
| Update the givenServiceLevelObjective. |
Except as otherwise noted, the content of this page is licensed under theCreative Commons Attribution 4.0 License, and code samples are licensed under theApache 2.0 License. For details, see theGoogle Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.
Last updated 2025-07-23 UTC.