From 1a7d35514389b59f2095477a3512d532d7c0a9d2 Mon Sep 17 00:00:00 2001 From: Carlos Alberto Cortez Date: Thu, 28 Jan 2021 16:49:29 +0100 Subject: [PATCH 1/6] Small clarification for default's service.name for exporters. --- specification/trace/sdk_exporters/jaeger.md | 2 ++ specification/trace/sdk_exporters/zipkin.md | 4 +++- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/specification/trace/sdk_exporters/jaeger.md b/specification/trace/sdk_exporters/jaeger.md index e9a95cabcd2..ba9e7e2894c 100644 --- a/specification/trace/sdk_exporters/jaeger.md +++ b/specification/trace/sdk_exporters/jaeger.md @@ -43,6 +43,8 @@ single process and exporters need to handle this case accordingly. Critically, Jaeger backend depends on `Span.Process.ServiceName` to identify the service that produced the spans. That field MUST be populated from the `service.name` attribute of the [`service` resource](../../resource/semantic_conventions/README.md#service). +If no `service.name` was specified, that field MUST be populated from the +[default](../../resource/sdk.md#sdk-provided-resource-attributes) `Resource`. ### InstrumentationLibrary diff --git a/specification/trace/sdk_exporters/zipkin.md b/specification/trace/sdk_exporters/zipkin.md index b6189dab7a9..1fb07bdfa4a 100644 --- a/specification/trace/sdk_exporters/zipkin.md +++ b/specification/trace/sdk_exporters/zipkin.md @@ -53,7 +53,9 @@ and Zipkin. Zipkin service name MUST be set to the value of the [resource attribute](../../resource/semantic_conventions/README.md): -`service.name`. In Zipkin it is important that the service name is consistent +`service.name`. If no `service.name` was specified, it MUST be populated from the +[default](../../resource/sdk.md#sdk-provided-resource-attributes) `Resource`. +In Zipkin it is important that the service name is consistent for all spans in a local root. Otherwise service graph and aggregations would not work properly. OpenTelemetry doesn't provide this consistency guarantee. Exporter may chose to override the value for service name based on a local root From 4114f7fcd824d19c6a527367ce8fd7553894be17 Mon Sep 17 00:00:00 2001 From: Carlos Alberto Cortez Date: Thu, 28 Jan 2021 17:38:00 +0100 Subject: [PATCH 2/6] Update specification/trace/sdk_exporters/jaeger.md MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Christian Neumüller --- specification/trace/sdk_exporters/jaeger.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/specification/trace/sdk_exporters/jaeger.md b/specification/trace/sdk_exporters/jaeger.md index ba9e7e2894c..11755ecb27e 100644 --- a/specification/trace/sdk_exporters/jaeger.md +++ b/specification/trace/sdk_exporters/jaeger.md @@ -43,7 +43,7 @@ single process and exporters need to handle this case accordingly. Critically, Jaeger backend depends on `Span.Process.ServiceName` to identify the service that produced the spans. That field MUST be populated from the `service.name` attribute of the [`service` resource](../../resource/semantic_conventions/README.md#service). -If no `service.name` was specified, that field MUST be populated from the +If no `service.name` is contained in a Span's Resource, that field MUST be populated from the [default](../../resource/sdk.md#sdk-provided-resource-attributes) `Resource`. ### InstrumentationLibrary From fc6783706d27264928b33ebf1b68edad29768b38 Mon Sep 17 00:00:00 2001 From: Carlos Alberto Cortez Date: Thu, 28 Jan 2021 17:38:17 +0100 Subject: [PATCH 3/6] Update specification/trace/sdk_exporters/zipkin.md MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Christian Neumüller --- specification/trace/sdk_exporters/zipkin.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/specification/trace/sdk_exporters/zipkin.md b/specification/trace/sdk_exporters/zipkin.md index 1fb07bdfa4a..37fb4557edf 100644 --- a/specification/trace/sdk_exporters/zipkin.md +++ b/specification/trace/sdk_exporters/zipkin.md @@ -53,7 +53,7 @@ and Zipkin. Zipkin service name MUST be set to the value of the [resource attribute](../../resource/semantic_conventions/README.md): -`service.name`. If no `service.name` was specified, it MUST be populated from the +`service.name`. If no `service.name` is contained in a Span's Resource, it MUST be populated from the [default](../../resource/sdk.md#sdk-provided-resource-attributes) `Resource`. In Zipkin it is important that the service name is consistent for all spans in a local root. Otherwise service graph and aggregations would From 784819a0508094327807e3ec065350f2ce27b4c5 Mon Sep 17 00:00:00 2001 From: Carlos Alberto Cortez Date: Thu, 28 Jan 2021 17:56:32 +0100 Subject: [PATCH 4/6] No fallback for Zipkin's service.name. --- specification/trace/sdk_exporters/zipkin.md | 3 --- 1 file changed, 3 deletions(-) diff --git a/specification/trace/sdk_exporters/zipkin.md b/specification/trace/sdk_exporters/zipkin.md index 37fb4557edf..e29b9055dc8 100644 --- a/specification/trace/sdk_exporters/zipkin.md +++ b/specification/trace/sdk_exporters/zipkin.md @@ -64,9 +64,6 @@ span to improve Zipkin user experience. *Note*, the attribute `service.namespace` must not be used for the Zipkin service name and should be sent as a Zipkin tag. -*Note*, exporter to Zipkin MUST allow to configure the default "fall back" name -to use as a Zipkin service name. - ### SpanKind The following table lists all the `SpanKind` mappings between OpenTelemetry and From 2ccc5d84bbd5ab0bf7f62e5a2fe23d9eb21e8be4 Mon Sep 17 00:00:00 2001 From: Carlos Alberto Cortez Date: Thu, 28 Jan 2021 18:22:45 +0100 Subject: [PATCH 5/6] Update CHANGELOG. --- CHANGELOG.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index dbb71e237a1..3e031b1fc0d 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -52,6 +52,9 @@ Updates: ([#1339](https://github.com/open-telemetry/opentelemetry-specification/pull/1339)) - Trace Exporters: Fix TODOs in Jaeger exporter spec ([#1374](https://github.com/open-telemetry/opentelemetry-specification/pull/1374)) +- Clarify that Jaeger/Zipkin exporters must to rely on the default Resource to + get service.name if none was specified. + ([#1386](https://github.com/open-telemetry/opentelemetry-specification/pull/1386)) ## v0.7.0 (11-18-2020) From fa20e52151a06afaefb52a9748dd83970f467969 Mon Sep 17 00:00:00 2001 From: Carlos Alberto Cortez Date: Fri, 29 Jan 2021 13:45:23 +0100 Subject: [PATCH 6/6] Update CHANGELOG.md Co-authored-by: Nikita Salnikov-Tarnovski --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 3e031b1fc0d..a8892d28fd8 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -52,7 +52,7 @@ Updates: ([#1339](https://github.com/open-telemetry/opentelemetry-specification/pull/1339)) - Trace Exporters: Fix TODOs in Jaeger exporter spec ([#1374](https://github.com/open-telemetry/opentelemetry-specification/pull/1374)) -- Clarify that Jaeger/Zipkin exporters must to rely on the default Resource to +- Clarify that Jaeger/Zipkin exporters must rely on the default Resource to get service.name if none was specified. ([#1386](https://github.com/open-telemetry/opentelemetry-specification/pull/1386))