We strongly recommend upgrading your Classic SLOs from
Service-Level Objectives Classic to
Service-Level Objectives to maximize capabilities and benefit from the newest enhancements.
Dynatrace offers an improved experience for
Service-Level Objectives (SLOs), allowing you to define tailored Service-Level Indicators (SLIs) using all available data points. This upgrade provides greater flexibility, customization, and integration with Grail.
Dynatrace provides two Service-Level Objectives application types:
Service-Level Objectives is our latest, Grail-powered application offering enhanced flexibility and customization options.
Service-Level Objectives Classic is the previous application with limited capabilities.
The following examples show an SLO in
Service-Level Objectives and multiple SLOs in
Dashboards.



The table below highlights the new functionality and shows the many reasons you should upgrade. It compares the capabilities of SLOs in
Service-Level Objectives and
Service-Level Objectives Classic.
| Capability | Service-Level Objectives Classic | Service-Level Objectives | Business impact |
|---|---|---|---|
Supported input for SLI definition | Limited to built-in or custom-calculated metrics | Supporting all data types in Grail, including business events, logs, spans, and time series | SLOs allow a finer granular configuration and tailored definition of the SLI. |
Segmenting, data filtering for SLO evaluation | Management zones | Segments allow detailed filtering of the dataset used for the SLO evaluation. | |
Adding SLO tags | — | SLO tags | Add SLO tags (key-value pairs) and then use them to filter SLOs when querying them via the API. |
Customized dashboard tiles | Classic dashboard tile | New dashboard SLO tiles allow more visual customization options, including what data should be shown and colorized. An additional SLO wizard overview allows for creating and editing SLOs in | |
Integration with other Dynatrace Apps | Integrated with Dynatrace Classic Apps | Integrated with latest Dynatrace Apps |
The main difference between the SLO and the Classic SLO is that the SLI in the SLO is represented as a single DQL query. The DQL query allows extensive customization possibilities, unlike metric and entity selectors in the Classic SLO.
The benefits of DQL-based SLOs are as follows:
An SLO typically shows specific characteristics you can configure in many possible ways.
The core SLO components are:
It's possible to set the following parameters:
In
Service-Level Objectives, the SLI is represented as a DQL (Dynatrace Query Language) query.
It's flexible and uses contextual data to represent the objectives.
Below is an example of a Classic SLO using the classic metric selectors, similar to a DQL query.

An SLO has two major parts: the Custom DQL and the Preview. In Custom DQL, you can define your DQL query. In Preview, you visualize the SLO.
The SLO DQL query is structured in a certain way to define the SLO and SLI. The SLO DQL example snippet defined in the Critical services or entities tab of the SLO has the following characteristics:
Define the data points.
timeseries {total=sum(dt.service.request.count), failures=sum(dt.service.request.failure_count)},
Specify the entity scope.
by: { dt.entity.service }
Display the information needed by using DQL filters.
| fieldsAdd name = entityName(dt.entity.service)| filter in(name, "astroshop-checkoutservice", "astroshop-cartservice", "astroshop-paymentservice", "astroshop-shippingservice", "astroshop-currencyservice", "astroshop-frontend", "astroshop-recommendationservice")
Calculate the SLI.
| fieldsAdd sli = (((total[] - failures[]) / total[]) * 100)| fields timeframe, interval, dt.entity.service, name, sli
Check in Preview the SLO and SLI statuses.

To upgrade a Classic SLO to SLO
Map your Classic SLO metric expression to Grail.
For complex metric expressions, you might need to adapt the DQL queries manually.
Convert the entity selectors to the corresponding DQL statement. For more information, see DQL best practices.
The following table shows the typical entity selectors for Classic SLOs and their DQL equivalent.
| Entity selector classic | DQL representation |
|---|---|
|
|
|
|
|
|
|
|
| Use Segments. Segments aren't related to permissions or access control. |
| See the relationship mapping table in Grail: Query monitored entities in Grail. |
If you use management zones for permissions and access control, see Grant access to entities with security context.
Enhance your SLI definition.
While you can upgrade most Classic SLOs to a one-to-one match in Grail, consider enhancing your SLI definitions by leveraging options that are not available with traditional metric expressions.
Take advantage of the new options:
To automate SLO management and evaluation, use the dedicated API endpoints. Reference the table below to upgrade your API integration for Classic SLO to SLO leveraging the SLO Service Public API.
Service-Level Objectives Classic | Service-Level Objectives |
|---|---|
For scalable SLO management and evaluation, use Configuration as Code overview on top of the SLO Service Public API.
To access the SLO Service Public API on your tenant
API. In the search results, see Support resources section and Dynatrace API below it.Configuration as Code via Terraform overview support the SLO Service Public API since v1.78.0, and the Dynatrace Terraform provider can be found dynatrace-oss/dynatrace | Terraform Registry.
Configuration as Code via Monaco overview supports the SLO Service Public API since v2.22.
We updated the SLO templates to use Smartscape 2.0 entity types and functions. If you have SLOs created from older templates, you need to migrate your SLOs to use the new entity references for improved performance and compatibility.
To migrate a Classic SLO based on an old template to an SLO with Smartscape 2.0 entity types, you have a couple of options:
To preserve the SLO's history and configuration, use the SLO Service Public API to upgrade the SLO.
This approach is API-only and not supported through the Dynatrace web UI.
Retrieve the Classic SLO configuration. Use the following API call.
GET /slos/{id}
Prepare the updated SLO configuration.
Map entity IDs. Use the Query Smartscape entity IDs sections below to find the Smartscape 2.0 entity IDs that correspond to your Dynatrace Classic entity IDs.
Identify the new template ID. Determine the Latest Dynatrace template ID that corresponds to your existing template, for example, if using a service availability template, find its Latest Dynatrace equivalent. Use this API call:
GET /objective-templates/{id}
Update the JSON payload. Modify the SLO configuration with the new values in the sliReference object.
{"name": "Your SLO Name","description": "Your SLO description","sliReference": {"templateId": "new-template-id","variables": [{"name": "serviceIds","value": "\"SMARTSCAPE-SERVICE-ID-123\""}]},...}
Key updates in the payload:
sliReference.templateId: New template ID.sliReference.variables[].value: Smartscape entity IDs, for example, SMARTSCAPE-SERVICE-ID-123.Validate the updated DQL query in the DQL editor, for example, in
Notebooks, or via the API preview endpoint.
Update the SLO using the following API call.
PUT /slos/{sloId}
Include the modified configuration in the request body.
Verify the updated SLO is working correctly and showing expected data.
Use this approach when you want to start with a new SLO or when using the API is too complex.
With this approach, you lose the historical data and trend analysis from the old SLO. Consider exporting or documenting all historical performance data before you delete any SLOs. You might need historical performance data for compliance or reporting purposes.
When working with Smartscape 2.0 entities, you need to map Classic entity IDs to their corresponding Smartscape 2.0 entity IDs. You can query this mapping using DQL:
smartscapeNodes "SERVICE"| fields id_classic, id, name
This query returns the following information:
id_classic: The SLO Classic entity ID.id: The new Smartscape 2.0 entity ID.name: The entity name.Replace SERVICE with the appropriate entity type for your use case, for example, HOST or K8S_CLUSTER.
New SLO templates created after this migration use the new entity references by default. Existing SLOs continue to work with Classic references, but migrating to the new templates is recommended for long-term compatibility.
An automated upgrade flow is under consideration; however, due to the highly customized nature of SLOs, a manual review is expected to deliver the best results. Use this opportunity to reassess and improve your SLIs, rather than simply copying them one-to-one.
For further optimization and guidance, contact your Dynatrace support team to maximize business impact from your service-level objectives.
Service-Level Objectives