From 28ada382331f1b2c747720c9d8e7075c181383cd Mon Sep 17 00:00:00 2001 From: Kim Nylander <104772500+knylander-grafana@users.noreply.github.com> Date: Tue, 10 Dec 2024 13:11:40 -0500 Subject: [PATCH] [DOC] Add clarification for metrics summary and traceQL metrics (#4316) * Add clarification for metrics summary and traceQL metrics * Apply suggestions from code review Co-authored-by: Jennifer Villa * Update docs/sources/tempo/api_docs/metrics-summary.md --------- Co-authored-by: Jennifer Villa (cherry picked from commit d730dfc91f3ccb57cca7b9637687a18392b85305) --- docs/sources/tempo/api_docs/_index.md | 29 ++++++++++++++++++--------- 1 file changed, 20 insertions(+), 9 deletions(-) diff --git a/docs/sources/tempo/api_docs/_index.md b/docs/sources/tempo/api_docs/_index.md index 4913ca2f718..8dde014a83e 100644 --- a/docs/sources/tempo/api_docs/_index.md +++ b/docs/sources/tempo/api_docs/_index.md @@ -357,14 +357,16 @@ Parameters: - `end = (unix epoch seconds)` Optional. Along with `start`, defines a time range from which tags should be returned. Providing both `start` and `end` includes blocks for the specified time range only. - ### Search tags V2 -Ingester configuration `complete_block_timeout` affects how long tags are available for search.If start or end aren't specified, it only fetches blocks that wasn't flushed to backend. +Ingester configuration `complete_block_timeout` affects how long tags are available for search. +If the start or end aren't specified, it only fetches blocks that weren't flushed to backend. -This endpoint retrieves all discovered tag names that can be used in search. The endpoint is available in the query frontend service in -a microservices deployment, or the Tempo endpoint in a monolithic mode deployment. The tags endpoint takes a scope that controls the kinds -of tags or attributes returned. If nothing is provided, the endpoint returns all resource and span tags. +This endpoint retrieves all discovered tag names that can be used in search. +The endpoint is available in the query frontend service in +a microservices deployment, or the Tempo endpoint in a monolithic mode deployment. +The tags endpoint takes a scope that controls the kinds of tags or attributes returned. +If nothing is provided, the endpoint returns all resource and span tags. ```bash GET /api/v2/search/tags?scope= @@ -381,6 +383,10 @@ Parameters: Optional. Along with `end` define a time range from which tags should be returned. - `end = (unix epoch seconds)` Optional. Along with `start` define a time range from which tags should be returned. Providing both `start` and `end` includes blocks for the specified time range only. +- `limit = (integer)` + Optional. Sets the maximum number of tags names allowed per scope. The query stops once this limit is reached for any scope. +- `maxStaleValues = (integer)` + Optional. Limits the search for tag values. The search stops if the number of stale (already known) values reaches or exceeds this limit. #### Example @@ -503,16 +509,21 @@ You can pass an optional URL query parameter, `q`, to your request. The `q` parameter is a URL-encoded [TraceQL query]({{< relref "../traceql" >}}). If provided, the tag values returned by the API are filtered to only return values seen on spans matching your filter parameters. -Queries can be incomplete: for example, `{ .cluster = }`. Tempo extracts only the valid matchers and build a valid query. +Queries can be incomplete: for example, `{ resource.cluster = }`. +Tempo extracts only the valid matchers and builds a valid query. +If an input is invalid, Tempo doesn't provide an error. Instead, +you'll see the whole list when a failure of parsing input. This behavior helps with backwards compatibility. Only queries with a single selector `{}` and AND `&&` operators are supported. - - Example supported: `{ .cluster = "us-east-1" && .service = "frontend" }` - - Example unsupported: `{ .cluster = "us-east-1" || .service = "frontend" } && { .cluster = "us-east-2" }` + - Example supported: `{ resource.cluster = "us-east-1" && resource.service = "frontend" }` + - Example unsupported: `{ resource.cluster = "us-east-1" || resource.service = "frontend" } && { resource.cluster = "us-east-2" }` + +Unscoped attributes aren't supported for filtered tag values. The following request returns all discovered service names on spans with `span.http.method=GET`: ``` -GET /api/v2/search/tag/.service.name/values?q="{span.http.method='GET'}" +GET /api/v2/search/tag/resource.service.name/values?q="{span.http.method='GET'}" ``` If a particular service name (for example, `shopping-cart`) is only present on spans with `span.http.method=POST`, it won't be included in the list of values returned.