-
Notifications
You must be signed in to change notification settings - Fork 276
[db] Add docs for context info propagation #2236
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from 11 commits
1529979
ab6e386
08b02a8
2c26648
0ccfda5
a6e65f4
886aa37
f633fa2
5b835f8
e021083
1bcbf0d
e6803f5
f986ee2
8794c1d
ec00e3c
fa6cf6d
2c0e01a
430957b
7f05f5e
5534272
9876582
89a4baf
0e7ff53
8effebc
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,22 @@ | ||
| # Use this changelog template to create an entry for release notes. | ||
| # | ||
| # If your change doesn't affect end users you should instead start | ||
| # your pull request title with [chore] or use the "Skip Changelog" label. | ||
|
|
||
| # One of 'breaking', 'deprecation', 'new_component', 'enhancement', 'bug_fix' | ||
| change_type: enhancement | ||
|
|
||
| # The name of the area of concern in the attributes-registry, (e.g. http, cloud, db) | ||
| component: db | ||
|
|
||
| # A brief description of the change. Surround your text with quotes ("") if it needs to start with a backtick (`). | ||
| note: Add doc for context information propagation | ||
|
|
||
| # Mandatory: One or more tracking issues related to the change. You can use the PR number here if no issue exists. | ||
| # The values here must be integers. | ||
| issues: [2162] | ||
|
|
||
| # (Optional) One or more lines of additional information to render under the primary note. | ||
| # These lines will be padded with 2 spaces and then inserted directly into the document. | ||
| # Use pipe (|) for multiline entries. | ||
| subtext: |
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -13,6 +13,8 @@ linkTitle: Spans | |
| - [Notes and well-known identifiers for `db.system.name`](#notes-and-well-known-identifiers-for-dbsystemname) | ||
| - [Sanitization of `db.query.text`](#sanitization-of-dbquerytext) | ||
| - [Generating a summary of the query](#generating-a-summary-of-the-query) | ||
| - [Propagating context to databases](#propagating-context-to-databases) | ||
| - [Recommended sqlcommenter attributes](#recommended-sqlcommenter-attributes) | ||
| - [Semantic conventions for specific database technologies](#semantic-conventions-for-specific-database-technologies) | ||
|
|
||
| <!-- tocstop --> | ||
|
|
@@ -478,6 +480,43 @@ Semantic conventions for individual database systems or specialized instrumentat | |
| MAY specify a different `db.query.summary` format as long as produced summary remains | ||
| relatively short and its cardinality remains low comparing to the `db.query.text`. | ||
|
|
||
| ## Propagating context to databases | ||
|
|
||
| **Status**: [Development][DocumentStatus] | ||
|
|
||
| Instrumentations SHOULD propagate the context information to the SQL queries following [sqlcommenter](https://google.github.io/sqlcommenter/spec/). | ||
|
||
|
|
||
| ### Recommended sqlcommenter attributes | ||
|
|
||
| | Attribute | Type | Description | Require level | Stability | | ||
| |------------------------|--------|---------------------------------------|------------------------------|----------------------------------------------------------------| | ||
| | `baggage.service.name` | string | Logical name of the service [1] | `Conditionally Required` [2] |  | | ||
|
||
| | `traceparent` | string | The trace context of current span [3] | `Recommended` [4] |  | | ||
|
|
||
| **[1] `baggage.service.name`:** MUST be the same for all instances of horizontally scaled services. If the value was not specified, SDKs MUST fall back to `unknown_service:` concatenated with [process.executable.name](https://opentelemetry.io/docs/specs/semconv/attributes-registry/process/), e.g. `unknown_service:bash`. If `process.executable.name` is not available, the value MUST be set to `unknown_service`. | ||
pellared marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
|
|
||
| [Baggage](https://www.w3.org/TR/baggage/) means you can pass data across services and processes, making it available to add to traces, metrics, or logs in those services. | ||
|
|
||
| **[2] `baggage.service.name`:** SHOULD be set if `traceparent` cannot be injected due to performance issues. | ||
|
|
||
| **[3] `traceparent`:** MUST be in the [text format](https://www.w3.org/TR/trace-context/#traceparent-header). | ||
|
|
||
| **[4] `traceparent`:** `traceparent` has extremely high-cardinality. It's RECOMMENDED to propagate this info if the high-cardinality is safe for the database observabilty engine. | ||
|
|
||
| **Examples:** | ||
|
|
||
| - Query with `baggage.service.name`: | ||
|
|
||
| ```sql | ||
| SELECT * FROM songs /* baggage.service.name=music-player%3Aplay */ | ||
| ``` | ||
|
|
||
| - Query with `baggage.service.name` and `traceparent` | ||
|
|
||
| ```sql | ||
| SELECT * FROM songs /* baggage.service.name=music-player%3Aplay, traceparent=00-0af7651916cd43dd8448eb211c80319c-b7ad6b7169203331-01 */ | ||
sincejune marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
| ``` | ||
|
|
||
| ## Semantic conventions for specific database technologies | ||
|
|
||
| More specific Semantic Conventions are defined for the following database technologies: | ||
|
|
||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -9,6 +9,8 @@ linkTitle: SQL Server | |
| <!-- toc --> | ||
|
|
||
| - [Spans](#spans) | ||
| - [Propagating context to SQL Server](#propagating-context-to-sql-server) | ||
| - [Recommended sqlcommenter attributes](#recommended-sqlcommenter-attributes) | ||
| - [Metrics](#metrics) | ||
|
|
||
| <!-- tocstop --> | ||
|
|
@@ -152,6 +154,29 @@ and SHOULD be provided **at span creation time** (if provided at all): | |
| <!-- END AUTOGENERATED TEXT --> | ||
| <!-- endsemconv --> | ||
|
|
||
| ### Propagating context to SQL Server | ||
sincejune marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
|
|
||
| **Status**: [Development][DocumentStatus] | ||
|
|
||
| Instrumentations SHOULD propagate the context information to the SQL queries following [sqlcommenter](https://google.github.io/sqlcommenter/spec/). | ||
|
|
||
| #### Recommended sqlcommenter attributes | ||
|
|
||
| | Attribute | Type | Description | Require level | Stability | | ||
| |------------------------|--------|---------------------------------------|-----------------------------|----------------------------------------------------------------| | ||
| | `baggage.service.name` | string | Logical name of the service [1] | `Conditionally Required`[2] |  | | ||
| | `traceparent` | string | The trace context of current span [3] | `Recommended` |  | | ||
|
|
||
| **[1] `baggage.service.name`:** MUST be the same for all instances of horizontally scaled services. If the value was not specified, SDKs MUST fall back to `unknown_service:` concatenated with [process.executable.name](https://opentelemetry.io/docs/specs/semconv/attributes-registry/process/), e.g. `unknown_service:bash`. If `process.executable.name` is not available, the value MUST be set to `unknown_service`. | ||
|
|
||
| [Baggage](https://www.w3.org/TR/baggage/) means you can pass data across services and processes, making it available to add to traces, metrics, or logs in those services. | ||
|
|
||
| **[2] `baggage.service.name`:** SHOULD be set if `traceparent` cannot be injected due to performance issues. | ||
|
|
||
| **[3] `traceparent`:** MUST be in the [text format](https://www.w3.org/TR/trace-context/#traceparent-header). | ||
|
|
||
| Instrumentations SHOULD make use of [SET CONTEXT_INFO](https://learn.microsoft.com/en-us/sql/t-sql/statements/set-context-info-transact-sql?view=sql-server-ver16) to add high-cardinality information(e.g. `traceparent`) as adding sql comments to queries changes their unique identifier in SQL Server. | ||
|
||
|
|
||
| ## Metrics | ||
|
|
||
| Microsoft SQL Server client instrumentations SHOULD collect metrics according to the general | ||
|
|
||
Uh oh!
There was an error while loading. Please reload this page.