From f6e19550130dfef2dadd0f30e3a21b76d3fe30a1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Thu, 25 Jul 2024 11:09:11 +0200 Subject: [PATCH 1/8] Define equality for Attributes and Attribute Collections --- specification/common/README.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/specification/common/README.md b/specification/common/README.md index 9f91708e647..aed9e558262 100644 --- a/specification/common/README.md +++ b/specification/common/README.md @@ -59,6 +59,8 @@ indices that are kept in sync (e.g., two attributes `header_keys` and `header_va both containing an array of strings to represent a mapping `header_keys[i] -> header_values[i]`). +Attributes are equal when their keys and values are equal. + See [Attribute Naming](https://github.com/open-telemetry/semantic-conventions/blob/main/docs/general/attribute-naming.md) for naming guidelines. See [Requirement Level](https://github.com/open-telemetry/semantic-conventions/blob/main/docs/general/attribute-requirement-level.md) for requirement levels guidelines. @@ -185,3 +187,7 @@ Some other implementations may use a streaming approach where every that individual attribute value being exported using a streaming wire protocol. In such cases the enforcement of uniqueness will likely be the responsibility of the recipient of this data. + +Collection of attributes are equal when they contain the same attributes, +irrespective of the order in which those elements appear +(unordered collection equality). From dd61daf5b7686f114e7961a3ef64c15d3bd88266 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Thu, 25 Jul 2024 11:12:17 +0200 Subject: [PATCH 2/8] Remove identifying fields term for Tracer, Meter, Logger, EventLogger. SDK MUST be able to export all passed input. --- specification/logs/bridge-api.md | 18 ++++-------------- specification/logs/event-api.md | 13 ++++--------- specification/logs/sdk.md | 4 ++++ specification/metrics/api.md | 14 ++++---------- specification/metrics/sdk.md | 8 ++++---- specification/trace/api.md | 17 +++-------------- specification/trace/sdk.md | 4 ++++ 7 files changed, 27 insertions(+), 51 deletions(-) diff --git a/specification/logs/bridge-api.md b/specification/logs/bridge-api.md index 6fccedd6f87..46b31114452 100644 --- a/specification/logs/bridge-api.md +++ b/specification/logs/bridge-api.md @@ -63,7 +63,7 @@ The `LoggerProvider` MUST provide the following functions: This API MUST accept the following [instrumentation scope](data-model.md#field-instrumentationscope) parameters: -* `name`: This name uniquely identifies the [instrumentation scope](../glossary.md#instrumentation-scope), +* `name`: Specifies the name of the [instrumentation scope](../glossary.md#instrumentation-scope), such as the [instrumentation library](../glossary.md#instrumentation-library) (e.g. `io.opentelemetry.contrib.mongodb`), package, module or class name. If an application or library has built-in OpenTelemetry instrumentation, both @@ -85,19 +85,9 @@ parameters: associate with emitted telemetry. This API MUST be structured to accept a variable number of attributes, including none. -`Logger`s are identified by `name`, `version`, and `schema_url` fields. When more -than one `Logger` of the same `name`, `version`, and `schema_url` is created, it -is unspecified whether or under which conditions the same or different `Logger` -instances are returned. It is a user error to create Loggers with different -`attributes` but the same identity. - -The term *identical* applied to `Logger`s describes instances where all -identifying fields are equal. The term *distinct* applied to `Logger`s describes -instances where at least one identifying field has a different value. - -The effect of associating a Schema URL with a `Logger` MUST be that the telemetry -emitted using the `Logger` will be associated with the Schema URL, provided that -the emitted data format is capable of representing such association. +The term *identical* applied to `Logger`s describes instances where all fields +are equal. The term *distinct* applied to `Logger`s describes instances where at +least one field has a different value. ## Logger diff --git a/specification/logs/event-api.md b/specification/logs/event-api.md index 9a769f498a0..17c1a95008c 100644 --- a/specification/logs/event-api.md +++ b/specification/logs/event-api.md @@ -98,7 +98,7 @@ The `EventLoggerProvider` MUST provide the following functions: This API MUST accept the following parameters: -* `name`: This name uniquely identifies the [instrumentation scope](../glossary.md#instrumentation-scope), +* `name`: Specifies the name of the [instrumentation scope](../glossary.md#instrumentation-scope), such as the [instrumentation library](../glossary.md#instrumentation-library) (e.g. `io.opentelemetry.contrib.mongodb`), package, module or class name. If an application or library has built-in OpenTelemetry instrumentation, both @@ -117,15 +117,10 @@ This API MUST accept the following parameters: associate with emitted telemetry. This API MUST be structured to accept a variable number of attributes, including none. -`EventLogger`s are identified by `name`, `version`, and `schema_url` fields. When more -than one `EventLogger` of the same `name`, `version`, and `schema_url` is created, it -is unspecified whether or under which conditions the same or different `EventLogger` -instances are returned. It is a user error to create `EventLogger`s with different -`attributes` but the same identity. +The term *identical* applied to `EventLogger`s describes instances where all +fields are equal. The term *distinct* applied to `EventLogger`s describes +instances where at least one field has a different value. -The effect of associating a Schema URL with a `EventLogger` MUST be that the telemetry -emitted using the `EventLogger` will be associated with the Schema URL, provided that -the emitted data format is capable of representing such association. ## EventLogger diff --git a/specification/logs/sdk.md b/specification/logs/sdk.md index be06ddc56b6..f1367235aac 100644 --- a/specification/logs/sdk.md +++ b/specification/logs/sdk.md @@ -63,6 +63,10 @@ It SHOULD only be possible to create `Logger` instances through a `LoggerProvide The `LoggerProvider` MUST implement the [Get a Logger API](bridge-api.md#get-a-logger). +The implementation MUST honor all passed parameters so that that the telemetry +emitted using the `Logger` will contain the data passed via the parameters, +provided that the emitted data format is capable of representing such data. + The input provided by the user MUST be used to create an [`InstrumentationScope`](../glossary.md#instrumentation-scope) instance which is stored on the created `Logger`. diff --git a/specification/metrics/api.md b/specification/metrics/api.md index 1103869a115..456833b878f 100644 --- a/specification/metrics/api.md +++ b/specification/metrics/api.md @@ -120,7 +120,7 @@ The `MeterProvider` MUST provide the following functions: This API MUST accept the following parameters: -* `name`: This name uniquely identifies the [instrumentation +* `name`: Specifies the name of the [instrumentation scope](../glossary.md#instrumentation-scope), such as the [instrumentation library](../glossary.md#instrumentation-library) (e.g. `io.opentelemetry.contrib.mongodb`), package, @@ -149,15 +149,9 @@ This API MUST accept the following parameters: it is up to their discretion. Therefore, this API MUST be structured to accept a variable number of attributes, including none. -Meters are identified by `name`, `version`, and `schema_url` fields. When more -than one `Meter` of the same `name`, `version`, and `schema_url` is created, it -is unspecified whether or under which conditions the same or different `Meter` -instances are returned. It is a user error to create Meters with different -attributes but the same identity. - -The term *identical* applied to Meters describes instances where all identifying -fields are equal. The term *distinct* applied to Meters describes instances where -at least one identifying field has a different value. +The term *identical* applied to Meters describes instances where all fields are +equal. The term *distinct* applied to Meters describes instances where at least +one field has a different value. ## Meter diff --git a/specification/metrics/sdk.md b/specification/metrics/sdk.md index 3dd0c6ecf10..41b36045893 100644 --- a/specification/metrics/sdk.md +++ b/specification/metrics/sdk.md @@ -119,6 +119,10 @@ It SHOULD only be possible to create `Meter` instances through a `MeterProvider` The `MeterProvider` MUST implement the [Get a Meter API](api.md#get-a-meter). +The implementation MUST honor all passed parameters so that that the telemetry +emitted using the `Meter` will contain the data passed via the parameters, +provided that the emitted data format is capable of representing such data. + The input provided by the user MUST be used to create an [`InstrumentationScope`](../glossary.md#instrumentation-scope) instance which is stored on the created `Meter`. @@ -128,10 +132,6 @@ working Meter MUST be returned as a fallback rather than returning null or throwing an exception, its `name` SHOULD keep the original invalid value, and a message reporting that the specified value is invalid SHOULD be logged. -When a Schema URL is passed as an argument when creating a `Meter` the emitted -telemetry for that `Meter` MUST be associated with the Schema URL, provided -that the emitted data format is capable of representing such association. - **Status**: [Development](../document-status.md) - The `MeterProvider` MUST compute the relevant [MeterConfig](#meterconfig) using the configured [MeterConfigurator](#meterconfigurator), and create diff --git a/specification/trace/api.md b/specification/trace/api.md index b06810ecc53..9e670503fd5 100644 --- a/specification/trace/api.md +++ b/specification/trace/api.md @@ -138,15 +138,9 @@ This API MUST accept the following parameters: - [since 1.13.0] `attributes` (optional): Specifies the instrumentation scope attributes to associate with emitted telemetry. -Tracers are identified by `name`, `version`, and `schema_url` fields. When more -than one `Tracer` of the same `name`, `version`, and `schema_url` is created, it -is unspecified whether or under which conditions the same or different `Tracer` -instances are returned. It is a user error to create Tracers with different -attributes but the same identity. - -The term *identical* applied to Tracers describes instances where all -identifying fields are equal. The term *distinct* applied to Tracers describes -instances where at least one identifying field has a different value. +The term *identical* applied to Tracers describes instances where all fields are +equal. The term *distinct* applied to Tracers describes instances where at least +one field has a different value. Implementations MUST NOT require users to repeatedly obtain a `Tracer` again with the same identity to pick up configuration changes. This can be @@ -161,11 +155,6 @@ the tracer could, for example, do a look-up with its identity in a map in the `TracerProvider`, or the `TracerProvider` could maintain a registry of all returned `Tracer`s and actively update their configuration if it changes. -The effect of associating a Schema URL with a `Tracer` MUST be that the -telemetry emitted using the `Tracer` will be associated with the Schema URL, -provided that the emitted data format is capable of representing such -association. - ## Context Interaction This section defines all operations within the Tracing API that interact with the diff --git a/specification/trace/sdk.md b/specification/trace/sdk.md index 622a1e1452b..57e3b4beca3 100644 --- a/specification/trace/sdk.md +++ b/specification/trace/sdk.md @@ -67,6 +67,10 @@ It SHOULD only be possible to create `Tracer` instances through a `TracerProvide The `TracerProvider` MUST implement the [Get a Tracer API](api.md#get-a-tracer). +The implementation MUST honor all passed parameters so that that the telemetry +emitted using the `Tracer` will contain the data passed via the parameters, +provided that the emitted data format is capable of representing such data. + The input provided by the user MUST be used to create an [`InstrumentationScope`](../glossary.md#instrumentation-scope) instance which is stored on the created `Tracer`. From f4af1911fd872033b70a1a2b91ab7c126010f813 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Thu, 25 Jul 2024 11:28:39 +0200 Subject: [PATCH 3/8] Format --- specification/logs/event-api.md | 1 - 1 file changed, 1 deletion(-) diff --git a/specification/logs/event-api.md b/specification/logs/event-api.md index 17c1a95008c..75947144f61 100644 --- a/specification/logs/event-api.md +++ b/specification/logs/event-api.md @@ -121,7 +121,6 @@ The term *identical* applied to `EventLogger`s describes instances where all fields are equal. The term *distinct* applied to `EventLogger`s describes instances where at least one field has a different value. - ## EventLogger The `EventLogger` is the entrypoint of the Event API, and is responsible for From e6984e331c0008efe3faf724ed29afeb76681d39 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Thu, 25 Jul 2024 18:30:03 +0200 Subject: [PATCH 4/8] Apply review suggestions --- specification/logs/bridge-api.md | 6 +++--- specification/logs/event-api.md | 4 ++-- specification/logs/sdk.md | 2 +- specification/metrics/api.md | 6 +++--- specification/metrics/sdk.md | 2 +- specification/trace/api.md | 6 +++--- specification/trace/sdk.md | 2 +- 7 files changed, 14 insertions(+), 14 deletions(-) diff --git a/specification/logs/bridge-api.md b/specification/logs/bridge-api.md index 46b31114452..33a496dfe75 100644 --- a/specification/logs/bridge-api.md +++ b/specification/logs/bridge-api.md @@ -85,9 +85,9 @@ parameters: associate with emitted telemetry. This API MUST be structured to accept a variable number of attributes, including none. -The term *identical* applied to `Logger`s describes instances where all fields -are equal. The term *distinct* applied to `Logger`s describes instances where at -least one field has a different value. +The term *identical* applied to `Logger`s describes instances where all +parameters are equal. The term *distinct* applied to `Logger`s describes +instances where at least one parameter has a different value. ## Logger diff --git a/specification/logs/event-api.md b/specification/logs/event-api.md index 75947144f61..ea5c58116fe 100644 --- a/specification/logs/event-api.md +++ b/specification/logs/event-api.md @@ -118,8 +118,8 @@ This API MUST accept the following parameters: variable number of attributes, including none. The term *identical* applied to `EventLogger`s describes instances where all -fields are equal. The term *distinct* applied to `EventLogger`s describes -instances where at least one field has a different value. +parameters are equal. The term *distinct* applied to `EventLogger`s describes +instances where at least one parameter has a different value. ## EventLogger diff --git a/specification/logs/sdk.md b/specification/logs/sdk.md index f1367235aac..9379c6b34c9 100644 --- a/specification/logs/sdk.md +++ b/specification/logs/sdk.md @@ -63,7 +63,7 @@ It SHOULD only be possible to create `Logger` instances through a `LoggerProvide The `LoggerProvider` MUST implement the [Get a Logger API](bridge-api.md#get-a-logger). -The implementation MUST honor all passed parameters so that that the telemetry +The implementation MUST honor all passed parameters so that the telemetry emitted using the `Logger` will contain the data passed via the parameters, provided that the emitted data format is capable of representing such data. diff --git a/specification/metrics/api.md b/specification/metrics/api.md index 456833b878f..9eee1971d4f 100644 --- a/specification/metrics/api.md +++ b/specification/metrics/api.md @@ -149,9 +149,9 @@ This API MUST accept the following parameters: it is up to their discretion. Therefore, this API MUST be structured to accept a variable number of attributes, including none. -The term *identical* applied to Meters describes instances where all fields are -equal. The term *distinct* applied to Meters describes instances where at least -one field has a different value. +The term *identical* applied to Meters describes instances where all parameters +are equal. The term *distinct* applied to Meters describes instances where at +least one parameter has a different value. ## Meter diff --git a/specification/metrics/sdk.md b/specification/metrics/sdk.md index 41b36045893..543d15a0bc2 100644 --- a/specification/metrics/sdk.md +++ b/specification/metrics/sdk.md @@ -119,7 +119,7 @@ It SHOULD only be possible to create `Meter` instances through a `MeterProvider` The `MeterProvider` MUST implement the [Get a Meter API](api.md#get-a-meter). -The implementation MUST honor all passed parameters so that that the telemetry +The implementation MUST honor all passed parameters so that the telemetry emitted using the `Meter` will contain the data passed via the parameters, provided that the emitted data format is capable of representing such data. diff --git a/specification/trace/api.md b/specification/trace/api.md index 9e670503fd5..f03ab0bf954 100644 --- a/specification/trace/api.md +++ b/specification/trace/api.md @@ -138,9 +138,9 @@ This API MUST accept the following parameters: - [since 1.13.0] `attributes` (optional): Specifies the instrumentation scope attributes to associate with emitted telemetry. -The term *identical* applied to Tracers describes instances where all fields are -equal. The term *distinct* applied to Tracers describes instances where at least -one field has a different value. +The term *identical* applied to Tracers describes instances where all parameters +are equal. The term *distinct* applied to Tracers describes instances where at +least one parameter has a different value. Implementations MUST NOT require users to repeatedly obtain a `Tracer` again with the same identity to pick up configuration changes. This can be diff --git a/specification/trace/sdk.md b/specification/trace/sdk.md index 57e3b4beca3..8e10ae5c09f 100644 --- a/specification/trace/sdk.md +++ b/specification/trace/sdk.md @@ -67,7 +67,7 @@ It SHOULD only be possible to create `Tracer` instances through a `TracerProvide The `TracerProvider` MUST implement the [Get a Tracer API](api.md#get-a-tracer). -The implementation MUST honor all passed parameters so that that the telemetry +The implementation MUST honor all passed parameters so that the telemetry emitted using the `Tracer` will contain the data passed via the parameters, provided that the emitted data format is capable of representing such data. From 63e45b02d2d5e6bed86898f67cf5e576dd480ce6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Mon, 16 Sep 2024 10:54:46 +0200 Subject: [PATCH 5/8] Update CHANGELOG.md --- CHANGELOG.md | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 60d659da883..e4a414db0b0 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -11,10 +11,19 @@ release. ### Traces +- Make all fields as identifying for Tracer. + ([#4161](https://github.com/open-telemetry/opentelemetry-specification/pull/4161)) + ### Metrics +- Make all fields as identifying for Meter. + ([#4161](https://github.com/open-telemetry/opentelemetry-specification/pull/4161)) + ### Logs +- Make all fields as identifying for Logger. + ([#4161](https://github.com/open-telemetry/opentelemetry-specification/pull/4161)) + ### Events ### Baggage @@ -29,6 +38,9 @@ release. ### Common +- Define attributes equality. + ([#4161](https://github.com/open-telemetry/opentelemetry-specification/pull/4161)) + ### Supplementary Guidelines ## v1.37.0 (2024-09-13) From c2baec9b528062de3aa435294ea5efa2befd6809 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Wed, 18 Sep 2024 22:04:06 +0200 Subject: [PATCH 6/8] Update CHANGELOG.md Co-authored-by: Cijo Thomas --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index e4a414db0b0..589999e9c32 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -38,7 +38,7 @@ release. ### Common -- Define attributes equality. +- Define equality for attributes and collection of attributes. ([#4161](https://github.com/open-telemetry/opentelemetry-specification/pull/4161)) ### Supplementary Guidelines From 091c8537430544beb31cf6be1a058e578330ae61 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Thu, 19 Sep 2024 15:44:56 +0200 Subject: [PATCH 7/8] Update CHANGELOG.md --- CHANGELOG.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 589999e9c32..9f1353ae19a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -11,17 +11,17 @@ release. ### Traces -- Make all fields as identifying for Tracer. +- Make all fields as identifying for Tracer. Previously attributes were omitted from being identifying. ([#4161](https://github.com/open-telemetry/opentelemetry-specification/pull/4161)) ### Metrics -- Make all fields as identifying for Meter. +- Make all fields as identifying for Meter. Previously attributes were omitted from being identifying. ([#4161](https://github.com/open-telemetry/opentelemetry-specification/pull/4161)) ### Logs -- Make all fields as identifying for Logger. +- Make all fields as identifying for Logger. Previously attributes were omitted from being identifying. ([#4161](https://github.com/open-telemetry/opentelemetry-specification/pull/4161)) ### Events From bc7a574575f08d0bb9749a209873b9f203219e48 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Tue, 24 Sep 2024 11:40:22 +0200 Subject: [PATCH 8/8] Remove redunant requirement --- specification/logs/sdk.md | 4 ---- specification/metrics/sdk.md | 4 ---- specification/trace/sdk.md | 4 ---- 3 files changed, 12 deletions(-) diff --git a/specification/logs/sdk.md b/specification/logs/sdk.md index 1e90c0f9593..5d29e2b6984 100644 --- a/specification/logs/sdk.md +++ b/specification/logs/sdk.md @@ -63,10 +63,6 @@ It SHOULD only be possible to create `Logger` instances through a `LoggerProvide The `LoggerProvider` MUST implement the [Get a Logger API](bridge-api.md#get-a-logger). -The implementation MUST honor all passed parameters so that the telemetry -emitted using the `Logger` will contain the data passed via the parameters, -provided that the emitted data format is capable of representing such data. - The input provided by the user MUST be used to create an [`InstrumentationScope`](../glossary.md#instrumentation-scope) instance which is stored on the created `Logger`. diff --git a/specification/metrics/sdk.md b/specification/metrics/sdk.md index ba3fefff0e7..f1c33c38fbb 100644 --- a/specification/metrics/sdk.md +++ b/specification/metrics/sdk.md @@ -119,10 +119,6 @@ It SHOULD only be possible to create `Meter` instances through a `MeterProvider` The `MeterProvider` MUST implement the [Get a Meter API](api.md#get-a-meter). -The implementation MUST honor all passed parameters so that the telemetry -emitted using the `Meter` will contain the data passed via the parameters, -provided that the emitted data format is capable of representing such data. - The input provided by the user MUST be used to create an [`InstrumentationScope`](../glossary.md#instrumentation-scope) instance which is stored on the created `Meter`. diff --git a/specification/trace/sdk.md b/specification/trace/sdk.md index 834c7988049..e406db86ddd 100644 --- a/specification/trace/sdk.md +++ b/specification/trace/sdk.md @@ -68,10 +68,6 @@ It SHOULD only be possible to create `Tracer` instances through a `TracerProvide The `TracerProvider` MUST implement the [Get a Tracer API](api.md#get-a-tracer). -The implementation MUST honor all passed parameters so that the telemetry -emitted using the `Tracer` will contain the data passed via the parameters, -provided that the emitted data format is capable of representing such data. - The input provided by the user MUST be used to create an [`InstrumentationScope`](../glossary.md#instrumentation-scope) instance which is stored on the created `Tracer`.