From f49b5cd076ffa761759c0ea02c2a6fc81ccf0a4a Mon Sep 17 00:00:00 2001 From: Liudmila Molkova Date: Tue, 26 Nov 2024 12:50:34 -0800 Subject: [PATCH] Add section on span status for databases (#1560) Co-authored-by: Trask Stalnaker --- .chloggen/1560.yaml | 4 +++ docs/database/database-spans.md | 60 +++++++++++++++++++++++++++++++++ 2 files changed, 64 insertions(+) create mode 100644 .chloggen/1560.yaml diff --git a/.chloggen/1560.yaml b/.chloggen/1560.yaml new file mode 100644 index 0000000000..35769898b7 --- /dev/null +++ b/.chloggen/1560.yaml @@ -0,0 +1,4 @@ +change_type: enhancement +component: db +note: Specify how to set span status for database operations. +issues: [1536, 1560] diff --git a/docs/database/database-spans.md b/docs/database/database-spans.md index 597a9de6cf..bf5dc93347 100644 --- a/docs/database/database-spans.md +++ b/docs/database/database-spans.md @@ -11,6 +11,8 @@ linkTitle: Client Calls - [Name](#name) +- [Status](#status) + - [Recording exception events](#recording-exception-events) - [Common attributes](#common-attributes) - [Notes and well-known identifiers for `db.system`](#notes-and-well-known-identifiers-for-dbsystem) - [Sanitization of `db.query.text`](#sanitization-of-dbquerytext) @@ -85,6 +87,62 @@ and SHOULD adhere to one of the following values, provided they are accessible: If a corresponding `{target}` value is not available for a specific operation, the instrumentation SHOULD omit the `{target}`. For example, for an operation describing SQL query on an anonymous table like `SELECT * FROM (SELECT * FROM table) t`, span name should be `SELECT`. +## Status + +[Span Status Code][SpanStatus] MUST be left unset if the operation has ended without any errors. + +Instrumentation SHOULD consider the operation as failed if any of the following is true: + +- the `db.response.status_code` value indicates an error + + > [!NOTE] + > + > The classification of status code as an error depends on the context. + > For example, a SQL STATE `02000` (`no_data`) indicates an error when the application + > expected the data to be available. However, it is not an error when the + > application is simply checking whether the data exists. + > + > Instrumentations that have additional context about a specific operation MAY use + > this context to set the span status more precisely. + > Instrumentations that don't have any additional context MUST follow the + > guidelines in this section. + +- an exception is thrown by the instrumented method call +- the instrumented method returns an error in another way + +When the operation ends with an error, instrumentation: + +- SHOULD set the span status code to `Error` +- SHOULD set the `error.type` attribute +- SHOULD set the span status description when it has additional information + about the error which is not expected to contain sensitive details and aligns + with [Span Status Description][SpanStatus] definition. + + It's NOT RECOMMENDED to duplicate `db.response.status_code` or `error.type` + in span status description. + + When the operation fails with an exception, the span status description SHOULD be set to + the exception message. + +### Recording exception events + +**Status**: [Experimental][DocumentStatus] + +When the operation fails with an exception, instrumentation SHOULD record +an [exception event](../exceptions/exceptions-spans.md) by default if, and only if, +the span being recorded is a local root span (does not have a local parent). + +> [!NOTE] +> +> Exception stack traces could be very long and are expensive to capture and store. +> Exceptions which are not handled by instrumented libraries are likely to be handled +> and logged by the caller. +> Exceptions that are not handled will be recorded by the outermost (local root) +> instrumentation such as HTTP or gRPC server. + +Instrumentation MAY provide a configuration option to record exceptions that +escape the surface of the instrumented API. + ## Common attributes These attributes will usually be the same for all operations performed over the same database connection. @@ -309,6 +367,7 @@ The `db.query.summary` attribute captures a shortened representation of a query which SHOULD have low-cardinality and SHOULD NOT contain any dynamic or sensitive data. > [!NOTE] +> > The `db.query.text` attribute is intended to identify individual queries. Even though > it is sanitized if captured by default, it could still have high cardinality and > might reach hundreds of lines. @@ -418,3 +477,4 @@ More specific Semantic Conventions are defined for the following database techno * [SQL](sql.md): Semantic Conventions for *SQL* databases. [DocumentStatus]: https://opentelemetry.io/docs/specs/otel/document-status +[SpanStatus]: https://github.com/open-telemetry/opentelemetry-specification/tree/v1.37.0/specification/trace/api.md#set-status