From 7b272de48afc2f068955ed92d29f59e23247aefa Mon Sep 17 00:00:00 2001 From: Bogdan Drutu Date: Tue, 23 Nov 2021 11:13:10 -0800 Subject: [PATCH] Remove the concept of supported temporality, keep preferred Signed-off-by: Bogdan Drutu --- CHANGELOG.md | 2 ++ specification/metrics/sdk.md | 36 +++++------------------------------- 2 files changed, 7 insertions(+), 31 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 74daf72bd29..c16c4ef0e41 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -17,6 +17,8 @@ release. ([#2101](/~https://github.com/open-telemetry/opentelemetry-specification/pull/2101)) - Mark In-memory, OTLP and Stdout exporter specs as Feature-freeze. ([#2131](/~https://github.com/open-telemetry/opentelemetry-specification/pull/2131)) +- Remove the concept of supported temporality, keep preferred. + ([#2154](/~https://github.com/open-telemetry/opentelemetry-specification/pull/2154)) ### Logs diff --git a/specification/metrics/sdk.md b/specification/metrics/sdk.md index 4380d824513..f0c13b43259 100644 --- a/specification/metrics/sdk.md +++ b/specification/metrics/sdk.md @@ -561,33 +561,11 @@ The SDK SHOULD provide a way to allow `MetricReader` to respond to idiomatic approach, for example, as `OnForceFlush` and `OnShutdown` callback functions. -The SDK SHOULD provide a way to allow [Aggregation +The SDK SHOULD provide a way to allow the preferred [Aggregation Temporality](./datamodel.md#temporality) to be specified for a `MetricReader` -instance during the setup (e.g. initialization, registration, etc.) time. The -following logic MUST be followed to determine which temporality to be used for a -`MetricReader`: - -* If the temporality is explicitly specified during `MetricReader` creation: - * If the specified temporality is supported by the `MetricReader`, use the - specified temporality. - * If the specified temporality is not supported by the `MetricReader`, treat - the conflicts as an error. It is unspecified _how_ these error should be - handled (e.g. it could fail fast during the SDK configuration time). Please - refer to [Error handling in OpenTelemetry](../error-handling.md) for the - general guidance. -* If the temporality is not explicitly specified: - * If the `MetricReader` only supports one temporality (either Cumulative or - Delta), use the supported temporality. - * If the `MetricReader` supports both Cumulative and Delta: - * If the `MetricReader` has a preferred temporality, use the preferred - temporality. - * If the `MetricReader` does not have a preferred temporality, use - Cumulative. - -If a `MetricReader` is backed by a `MetricExporter` (e.g. a [Periodic exporting -MetricReader](#periodic-exporting-metricreader) configured with an [OTLP -Exporter](./sdk_exporters/otlp.md)) it MUST use the underlying -`MetricExporter`'s preferred + supported temporality. +instance during the setup (e.g. initialization, registration, etc.) time. If the +preferred temporality is explicitly specified then the SDK SHOULD respect that, +otherwise use Cumulative. [OpenTelemetry SDK](../overview.md#sdk) authors MAY choose the best idiomatic design for their language: @@ -599,10 +577,6 @@ authors MAY choose the best idiomatic design for their language: [Gauge](./datamodel.md#gauge), or keep consuming it as Cumulative due to the consideration of [memory efficiency](./supplementary-guidelines.md#memory-management)? -* If an invalid combination of settings occurred (e.g. if a `MetricReader` - instance is set to use Cumulative, and it has an associated [Push Metric - Exporter](#push-metric-exporter) instance which has the temporality set to - Delta), would the SDK want to fail fast or use some fallback logic? * Refer to the [supplementary guidelines](./supplementary-guidelines.md#aggregation-temporality), which have more context and suggestions. @@ -678,7 +652,7 @@ example: pipe. `MetricExporter` SHOULD provide a way to allow `MetricReader` to retrieve its -preferred and supported temporality. +preferred temporality. ### Push Metric Exporter