Documentation forSolarWinds Observability SaaS

Traces Explorer

A trace is the path of a single request through an application. SolarWinds Observability SaaS gathers traces continuously from observed services and mines them for data. Traces provide information about what happens as a request moves across multiple hosts and services. They can help you understand upstream and downstream service dependencies, assess performance at every step in the request, and troubleshoot issues such as errors or high latency.

The Traces Explorer provides a high-level overview of your traces, as well as detailed insights into each trace.

Open the Traces Explorer

To access the Traces Explorer, click Analyze in the left pane, and then click Traces. The Traces page displays high-level information about traces that occurred during the default time period.

The Traces Explorer can also be accessed from the details view of other entities. It displays information about traces associated with the selected entity.

  • From the Service details view, click the Traces tab.
  • From the Service details view, go to the Insights tab and select the Errors sub-tab. Then click a number in the Occurrences column to view trace information associated with that group of errors. You can even narrow down to see exceptions only.
  • From the Service details view, go to the Insights tab and choose the Queries sub-tab. Then click a number in the Occurrences column to view trace information associated with that group of query operations.
  • From the Service details view, go to the Insights tab and select the Caches sub-tab. Then click a number in the Occurrences column to view trace information associated with that group of cache operations.
  • From the Service details view, go to the Insights tab and select the Remote Services sub-tab. Then click a number in the Occurrences column to view trace information associated with that group of remote services.
  • From the Website entity details view, click in the Traces tab.

Specify the type of traces to view

By default, the Traces Explorer displays Traced Requests, or traces of requests to a service. Select an option from the drop-down menu at the top of the page to see traces of database queries, remote service calls, cache calls, or errors.

The type of traces you select determines which table columns are shown and what filters are available.

Change the time period

The Traces Explorer displays data collected during the specified time period. To change the time period, click the drop-down menu in the upper-right corner and choose how much historical data to display. You can choose to view all recent data for standard lengths of time, or to view data between two dates.

To show data from a custom time period, choose Custom. In the calendar that appears, click the starting date of your time period and click the ending date. The time period's start and end times default to the current time. To change a start or end time, click the clock next to the time you want to change and click the desired time.

Locate specific traces

To locate specific traces, you can apply filters or search by tag.

Filter traces

Apply filters to further specify which traces to display.

The Transaction filter, which shows only requests from a certain type of transaction, is available for all trace types.

The Status filter narrows down traces by Error, Unset, and explicit OK request statuses, and is available for all trace types.

The Percentile slider filters response time durations of traces within the selected percentile range during the time period. Percentiles show where a particular response time falls compared to the average of all response time durations. You can use this slider to set the minimum and maximum percentiles to filter out outliers from the Traces List.

Other filters are available based on the selected trace type. For example, if you select Traced Queries, you could filter the list based on database type, database host, query operation, or the table being queried.

Apply filters

  1. If the Filters pane is closed, click the filter icon to open it.

    The Filters pane lists the filters available for the selected entity type.

  2. Select one or more values for each filter you want to apply.

    The Traces Explorer lists only the entities that meet the filter criteria. The Search box displays the tag and value(s) that correspond to each filter you applied.

Clear filters

To remove individual filters, clear the values you want to remove. To remove all filters, click Clear All at the bottom of the Filters pane.

Display the associated tag name

Hover over the information icon next to a filter to display the tag name related to that filtration option. These tag names can be used in the Search bar and the Metrics Explorer.

Search for traces

Each filter option corresponds to a tag. However, some tags available in the Search box are not available in the Filters pane.

  1. Click inside the Search box.

    A drop-down menu shows the tags available for the selected trace type.

  2. Click the tag you want to filter by.

    The drop-down menu shows all values for the selected tag that are associated with observed traces.

  3. Click a value to select it, and then press Enter to perform the search.

    The Traces Explorer lists only traces with the specified tag value.

    The Search box displays your selections in the format tag:value, and the corresponding filters are selected in the Filters pane.

    To further refine the list, you can add other tags. If you include multiple criteria, entities must meet all criteria.

Saved searches

If you regularly use the same combination of search criteria (applied filters or tags), you can save the search to quickly run it again.

Save a search

  1. Apply filters or enter search criteria to define the search you want to save.

  2. Click the folder icon on the right side of the Search box, and click Save Search.

    The Create Saved Search dialog opens.

  3. Enter a name to identify the search.

  4. If you want the saved search to be available only to you, select Private.

  5. Click Save.

Run a saved search

  1. Click the folder icon on the right side of the Search box.

    The drop-down menu lists the saved searches you have access to.

  2. Click the name of the search you want to run.

Select boxes on the heatmap to show only those traces

Click a box on the heatmap to select it, or hold the cursor down and drag the mouse pointer to select a group of boxes. The table below the heatmap lists only the traces that the selected boxes represent.

Click the heatmap anywhere outside the selected area to deselect the boxes and display information about all traces represented on the heatmap.

About the trace heatmap

The trace heatmap provides information about the traces that are currently selected for display (based on time period, filters, or other specifications):

  • The x-axis indicates when a trace ran. Each unit represents a time period (for example, from 2022-09-21 02:41:47 to 2022-09-21 02:42:16),

  • The y-axis indicates the duration of a trace. Each unit represents a time range (for example, between 6.7 ms and 7 ms).

  • Each box represents the traces that ran during the time period and whose duration was within the time range.

    To identify traces with the highest latency, look for boxes near the top of the heatmap.

  • The intensity of the box color indicates the number of traces the box represents. There are nine color variations. In Light theme, darker boxes represent higher numbers of traces. In Dark theme, lighter boxes represent higher numbers of traces.

    Error traces are shades of red. All other trace types are shades of blue.

Hover over a box on the heatmap to see details about the number of traces it represents and the duration of those traces.

The table below the heatmap lists each trace represented on the heatmap. The information shown about each trace includes the service and transaction the trace was a part of, the date and time of the trace, and additional details depending on what type of trace is selected.

Click the name of any entity listed in the table (for example, service, transaction, website, or host) to display information about that entity in the Entity Explorer.

Display trace details

In the table below the heatmap, click in the Details column to view detailed information about a trace and the spans that make up that trace. A span represents a specific operation within a trace.

The details view includes information about any errors that occurred during the trace, any queries executed during the trace, and any log events associated with the trace. It also includes a graphical representation of the spans within the trace. You can display detailed information about each span. Use the span information to understand the request flow and to identify where any errors or performance issues occurred. Span details include the duration of the span (both as a time and as a percentage of the total trace duration), which can help you prioritize troubleshooting activities.

Trace Summary

The components at the top of the page provide key information for the trace immediately. You can view the time stamp at the start of the trace, roughly how long ago before the current time that the trace was recorded, total trace duration, the main service associated with the trace with a link to details for that service, HTTP method associated with the root span and link to the transaction details, and color-coded HTTP status response code and incomplete trace indicator, when applicable.

Reasons for an incomplete trace may include:

  • Missing root span - the most common reason for an incomplete trace, typically caused when the initial request operation is not captured.

  • Multiple root spans - the trace shows more than one top-level operation, suggesting concurrency or fragmentation.

  • Orphaned spans - one or more child spans lack a parent span, or there is a mismatch between parent and child span IDs.

The total span and total error count during the trace appear to the right of the summary.

Trace Details tab

The Trace Details tab contains the execution breakdown by request, as well as the full, interactive span visualization and tabbed performance information. By default, the request associated with the main service and root span is selected in the Trace Request selector drop down.

Request Selector

Every distributed trace is divided into requests. A request is a continuous segment of a trace executed within a single service. It begins with an entry point span — the first span in the service — which has an associated transaction.

A transaction represents the operation executed by the service. It is derived from the HTTP request being processed, the invoked RPC method name, or the name of the entry span itself.

The trace Request Selector lists all requests that occurred in the trace in a tree structure, and can be used as a filter to narrow down data displayed in the Trace Details tab.

Execution Breakdown

The Execution Breakdown shows the duration of the request span (as a time and as a percentage of the total selected request duration) and in what part of the system it was spent: locally, remote, database, and cache. Use the selector to select child requests to see a more focused execution breakdown and tabbed information on performance data specific to each child request.

If the selected request contains an asynchronous operation, the breakdown will not be available.

About the span visualizations

The visualization in the middle of the page shows the spans within the trace. Each trace starts with a root span, which represents the entire operation. A trace can also include one or more child spans that describe sub-operations. Choose between the Waterfall Span View, a view along a flattened Zoom bar, or Tree View, which is a more vertical hierarchy. When looking into a trace that contains many spans, you can select one or more requests to visualize out of the total spans, including any errors that occurred within their durations.

Span Visualization Tools

The Total Spans are displayed in the upper left of the Spans visualization section for convenience, as well as the number of spans and errors in the selected request (selected in the Request Selector drop-down above). On the upper right of the Spans section, you can select a category in the Group by drop-down menu to group the span data. Group spans either by Span Name or by Database and Cache Calls. The Waterfall Trace View and Tree View selectors are located next to the drop-down. Use the Expand/Collapse toggle to expand either the Waterfall Span View or Tree View when traces contain a large number of spans or many nested spans, then use collapse when not needed. A reset button also becomes enabled when zoomed into the Waterfall trace chart.

Waterfall Trace View

The Waterfall Trace View shows all spans in a horizontal view of spans by their start time. The waterfall view is always zoomed into the selected request. When All Requests is selected, the timeline displays the whole trace. When a request with a shorter duration than the whole trace is selected, the timeline will be zoomed in to show the selected request.

The Waterfall Trace View contains two sections:

  • The main section shows all spans displayed in chronological order. The length of the rectangle that represents a span indicates the span's duration. Its position on the graph represents the span's execution order.

    If span B is executed after span A, it is shown to the right of span A.

    If span B is presented below span A it does not always indicate a parent-child relationship (each span can belong to different requests).

    Spans that are called asynchronously have a striped background, as shown in the example below.

    Image shows an asychronously-called span with a diagonal stripe background.

    If a span contains an error, it is marked with a red indicator at the start of the span.

    Image shows a span with a red error indicator at the start of the span duration.

  • The Zoom bar at the bottom provides a flattened overlay of the all spans on a single bar. It includes time indicators and, if errors occurred, symbols to indicate when they occurred. Use the Zoom bar to navigate around the main section.

Magnify part of the main section of the Waterfall Trace View
  1. By default, the entire trace is selected in the waterfall view. Click and drag the vertical handles on the left and right sides of the blue selection window in the Zoom bar to re-size the view, or select a child request in the drop down, which will zoom into that part of the trace.

  2. Hover over the selected area to click and drag the entire selection along the span.

  3. Click and drag the handles of the zoom area to adjust or return the view to normal.

  4. The chart can also be zoomed in by selecting a horizontal area on the main section.

    Image showing zoomed in area selected from the main section of the waterfall trace view using mouse.

  5. To reset Zoom bar selection to the selected request, use the reset button in the widget header section:

Tree View

The Tree View displays a vertical parent-child hierarchy of all spans in the trace, including span layer and duration, with the ability to filter based on specific operation. Any spans containing errors are indicated with an error icon. By default the selected request is highlighted and expanded, and nested spans contained within it are collapsed.

Use the arrow buttons to expand parent spans individually or all at once (next to Span Name header) to show child spans. The corresponding chart to the right of the Tree shows a mini-waterfall of the selected spans. You can also collapse spans when not needed. Clicking on spans themselves opens the Inspector panel for more details, described in the next section.

Tree View of all the spans in the trace

Display details about a span

To view information about a span, click the rectangle that represents that span in the main section of the waterfall span or tree view. The Inspector Panel displays detailed information, including raw data and code profiles when available, as well as any stacktraces (formerly backtraces), queries, errors, or log events associated with the span.

If there are other spans that occurred before or after that span within the span layer, you can click the right or left arrow in the upper-right corner of the panel to display information about the span before or after the current span.

Display details about a span layer

With the Inspector Panel open to show information about a span, click the arrow in the upper-left corner of the panel to display information about the span layer. You can then use the Select Request drop-down to navigate and select layers to update information in the Inspector panel.

The Inspector Panel displays all information about all the spans in the span layer.

Other tables in the Trace Details

Depending on the trace type, related information will populate the tables below the waterfall span view or tree view, including queries, remote calls, cache calls, errors, and logs associated with the specific trace. Clicking the span or calls listed will open further detailed information in the Inspector Panel, which specifies its span layer and durations.

Queries

Use information on the Queries tab to view all queries linked to a trace and analyze the performance of each one, as well as any errors that occurred. View DBO information such as query details, sample details when the query is sampled, and visual explain plan from Trace Details. For more information, including setup, see Integrate APM with DBO.

Remote Calls

Use Remote Calls information to identify and troubleshoot the remote services calls related to the trace that consume the most time, including frequent calls and poorly performing calls, as well as any errors that may have occurred. View each of the remote procedure calls (RPC) that occurred within the trace span, including the remote service, remote transaction, and request method. Through this information, as well as the details available in the Inspector Panel, you can gain more insight into all remote services and track request flow across many services within a distributed system.

Gray text may indicate that only part of the trace was captured, so some information is not available.

Cache Calls

Cache Calls shows calls to caches that the service made during the trace, including associated errors. Visibility into all Cache Operations in the Trace Details allows you to monitor caching performance by identifying when a cache hit or miss occurs within the overall flow of requests.

Errors

View detailed information about errors that occurred during the trace by clicking each error listed in the Errors tab, if any, including error message and time of occurrence.

Logs

Use the Logs tab to view log information for the selected trace. Log search and display tools are also available in this tab. For more information, see Logs Explorer

Event Graph tab

The Event Graph presents an interactive map of the trace’s journey through the spans. Each card represents an entry or exit event (can also be labeled as start and end) in a pair, and is displayed in the order of occurrence. The entry and exit event card pairs match colors to easily distinguish one event pair from another. Arrows show connection between the pairs and path taken between spans. By default, the graph cards are colored by span name. Use the drop down to choose a different color pattern, such as by service or node.

Event Data

Click each card to view details about the event, similar to the Inspector Panel available in the Trace Details tab. Plus, see valuable debug analytics to quickly validate the trace over all events. Use the search bar to find specific data points, such as event ID or event type.