Skip to content
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

Add SDK span telemetry metrics #1631

Open
wants to merge 42 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 34 commits
Commits
Show all changes
42 commits
Select commit Hold shift + click to select a range
8f2b666
Added SDK span telemetry metrics
JonasKunz Nov 29, 2024
8b2a1db
Fix formatting
JonasKunz Nov 29, 2024
8bbea82
Fix yamllint
JonasKunz Nov 29, 2024
e15696f
Merge remote-tracking branch 'otel/main' into sdk-telemetry
JonasKunz Nov 29, 2024
cef63f2
Changelog
JonasKunz Nov 29, 2024
c24bccc
Reuse error.type
JonasKunz Nov 29, 2024
34e56e7
Use enum for processor and exporter type attributes
JonasKunz Nov 29, 2024
4248917
Renamed trace to span namespace
JonasKunz Nov 29, 2024
2174d24
Fixed invalid metric name
JonasKunz Nov 29, 2024
0e54b96
fix lots of dumb mistakes
JonasKunz Nov 29, 2024
c62be64
Added queue_capacity metric
JonasKunz Nov 29, 2024
2f491df
Clarified meaning of submitted
JonasKunz Dec 3, 2024
1388eac
replaced spans_failed with spans_processed metric
JonasKunz Dec 3, 2024
2c60a71
Tried clarifying elemetry.sdk.component.id
JonasKunz Dec 3, 2024
0cfb94d
Merge branch 'main' into sdk-telemetry
JonasKunz Dec 6, 2024
15b37aa
Merge branch 'main' into sdk-telemetry
JonasKunz Jan 2, 2025
8ae4b58
Merge branch 'main' into sdk-telemetry
JonasKunz Jan 13, 2025
67ab2d0
Moved from telemetry. to otel. namespace
JonasKunz Jan 14, 2025
598636f
mend
JonasKunz Jan 14, 2025
b0fd83d
Rename spans_submitted to spans_exported
JonasKunz Jan 14, 2025
27f7690
Cleanup metrics with review suggestions
JonasKunz Jan 14, 2025
f1e1404
Clarify rejected data handling
JonasKunz Jan 14, 2025
4db7605
removed type in favor of component.name
JonasKunz Jan 14, 2025
26e21b2
Use {span} as unit
JonasKunz Jan 14, 2025
0ce6583
Merge branch 'main' into sdk-telemetry
JonasKunz Jan 14, 2025
820c5c6
Lint fixes
JonasKunz Jan 14, 2025
ef5bd53
Remove trailing empty line
JonasKunz Jan 14, 2025
8c10557
Merge branch 'main' into sdk-telemetry
JonasKunz Jan 16, 2025
ff663de
Merge branch 'main' into sdk-telemetry
JonasKunz Jan 17, 2025
833352b
Fix attribute registry name
JonasKunz Jan 20, 2025
226b42f
Renamed otel.is_sampled to otel.span.is_sampled
JonasKunz Jan 20, 2025
a5374c3
Merge branch 'main' into sdk-telemetry
JonasKunz Jan 20, 2025
e9aa0ee
Merge branch 'main' into sdk-telemetry
JonasKunz Jan 22, 2025
53ecd6c
Merge branch 'main' into sdk-telemetry
AlexanderWert Jan 23, 2025
1a82268
Remove leftover unused attributes
JonasKunz Jan 23, 2025
37d5810
Merge branch 'main' into sdk-telemetry
JonasKunz Jan 23, 2025
e737b7d
Added back reworked otel.sdk.component.type attribute
JonasKunz Jan 24, 2025
772d29a
Fix lint
JonasKunz Jan 24, 2025
c99e3ae
Merge branch 'main' into sdk-telemetry
JonasKunz Jan 24, 2025
935c01c
Fix otel.sdk.component.type enum value descriptions
JonasKunz Jan 24, 2025
04c0085
Fix missing _span prefixes
JonasKunz Jan 24, 2025
667028d
Fix another missing _span prefix
JonasKunz Jan 24, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
22 changes: 22 additions & 0 deletions .chloggen/sdk-span-metrics.yaml
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: 'otel'

# A brief description of the change. Surround your text with quotes ("") if it needs to start with a backtick (`).
note: Adds SDK self-monitoring metrics for span processing

# 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: [1631]

# (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:
51 changes: 51 additions & 0 deletions docs/attributes-registry/otel.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@

- [OTel Attributes](#otel-attributes)
- [OTel Scope Attributes](#otel-scope-attributes)
- [OTel SDK Telemetry Attributes](#otel-sdk-telemetry-attributes)
- [Deprecated OTel Library Attributes](#deprecated-otel-library-attributes)

## OTel Attributes
Expand All @@ -16,6 +17,7 @@ Attributes reserved for OpenTelemetry

| Attribute | Type | Description | Examples | Stability |
|---|---|---|---|---|
| <a id="otel-span-is-sampled" href="#otel-span-is-sampled">`otel.span.is_sampled`</a> | boolean | The sampled trace flag of the span | | ![Experimental](https://img.shields.io/badge/-experimental-blue) |
| <a id="otel-status-code" href="#otel-status-code">`otel.status_code`</a> | string | Name of the code, either "OK" or "ERROR". MUST NOT be set if the status code is UNSET. | `OK`; `ERROR` | ![Stable](https://img.shields.io/badge/-stable-lightgreen) |
| <a id="otel-status-description" href="#otel-status-description">`otel.status_description`</a> | string | Description of the Status if it has a value, otherwise not set. | `resource not found` | ![Stable](https://img.shields.io/badge/-stable-lightgreen) |

Expand All @@ -37,6 +39,55 @@ Attributes used by non-OTLP exporters to represent OpenTelemetry Scope's concept
| <a id="otel-scope-name" href="#otel-scope-name">`otel.scope.name`</a> | string | The name of the instrumentation scope - (`InstrumentationScope.Name` in OTLP). | `io.opentelemetry.contrib.mongodb` | ![Stable](https://img.shields.io/badge/-stable-lightgreen) |
| <a id="otel-scope-version" href="#otel-scope-version">`otel.scope.version`</a> | string | The version of the instrumentation scope - (`InstrumentationScope.Version` in OTLP). | `1.0.0` | ![Stable](https://img.shields.io/badge/-stable-lightgreen) |

## OTel SDK Telemetry Attributes

Attributes used for OpenTelemetry SDK self-monitoring

| Attribute | Type | Description | Examples | Stability |
|---|---|---|---|---|
| <a id="otel-sdk-component-name" href="#otel-sdk-component-name">`otel.sdk.component.name`</a> | string | A name uniquely identifying the instance of the OpenTelemetry SDK component within its containing SDK instance. [1] | `batch-span-0`; `custom-name` | ![Experimental](https://img.shields.io/badge/-experimental-blue) |
| <a id="otel-sdk-exporter-type" href="#otel-sdk-exporter-type">`otel.sdk.exporter.type`</a> | string | A name identifying the type of the OpenTelemetry SDK exporter. | `otlp-grpc`; `jaeger` | ![Experimental](https://img.shields.io/badge/-experimental-blue) |
| <a id="otel-sdk-processor-type" href="#otel-sdk-processor-type">`otel.sdk.processor.type`</a> | string | A name identifying the type of the OpenTelemetry SDK processor. | `batch-span`; `MyCustomProcessor` | ![Experimental](https://img.shields.io/badge/-experimental-blue) |

**[1] `otel.sdk.component.name`:** The attribute value MUST follow a `<type-name>/<instance-counter>` pattern, e.g. `batching_span_processor/0`.

For components corresponding to SDK specification concepts, the `type-name` MUST have the following values:

* `batching_span_processor` for the SDK Batching Span Processor
* `simple_span_processor` for the SDK Simple Span Processor
* `otlp_grpc_exporter` for the OTLP exporter over gRPC with protobuf serialization
* `otlp_http_exporter` for the OTLP exporter over HTTP with protobuf serialization
* `otlp_http_json_exporter` for the OTLP exporter over HTTP with JSON serialization

Other components SHOULD use the language and implementation dependant type name of the component for `type-name`, e.g. the class name in Java.

The value of `instance-counter` MUST be automatically assigned by the component and uniqueness within the enclosing SDK instance MUST be guaranteed.
Because this attribute is used in metrics, the component implementation MUST ensure a low cardinality. E.g. a UUID MUST NOT be use for <instance-counter>.
Instead, `<instance-counter>` MAY be implemented by using a monotonically increasing counter (starting with `0`), which is incremented every time an
instance of the given component type is started.

For example, the first Batching Span Processor will have `batching_span_processor/0` as `otel.sdk.component.name`, the second one `batching_span_processor/1` and so on.
These values will therefore be reused in the case of an application restart.

---

`otel.sdk.exporter.type` has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

| Value | Description | Stability |
|---|---|---|
| `otlp-grpc` | OTLP exporter over gRPC with protobuf serialization | ![Experimental](https://img.shields.io/badge/-experimental-blue) |
| `otlp-http` | OTLP exporter over HTTP with protobuf serialization | ![Experimental](https://img.shields.io/badge/-experimental-blue) |
| `otlp-http-json` | OTLP exporter over HTTP with JSON serialization | ![Experimental](https://img.shields.io/badge/-experimental-blue) |

---

`otel.sdk.processor.type` has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

| Value | Description | Stability |
|---|---|---|
| `batch-span` | The builtin SDK Batching Span Processor | ![Experimental](https://img.shields.io/badge/-experimental-blue) |
| `simple-span` | The builtin SDK Simple Span Processor | ![Experimental](https://img.shields.io/badge/-experimental-blue) |

## Deprecated OTel Library Attributes

Describes deprecated otel.library attributes.
Expand Down
1 change: 1 addition & 0 deletions docs/general/metrics.md
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ The following semantic conventions surrounding metrics are defined:
* [K8s](/docs/system/k8s-metrics.md): For K8s metrics.
* [Process](/docs/system/process-metrics.md): For standard process metrics.
* [Runtime Environment](/docs/runtime/README.md#metrics): For runtime environment metrics.
* [OTel SDK Telemetry](/docs/otel/sdk-metrics.md): Metrics emitted by the OpenTelemetry SDK components.

Apart from semantic conventions for metrics, [traces](trace.md), [logs](logs.md), and [events](events.md), OpenTelemetry also
defines the concept of overarching [Resources](https://github.com/open-telemetry/opentelemetry-specification/tree/v1.40.0/specification/resource/sdk.md) with
Expand Down
Loading
Loading