From c122d4325dc15c31517f11e7752a83c36c80dd8e Mon Sep 17 00:00:00 2001 From: Timothy Mothra Date: Thu, 25 May 2023 15:38:03 -0700 Subject: [PATCH] Add support for HttpSemanticConvention breaking changes (part2) (#4514) --- .../Implementation/HttpInMetricsListener.cs | 5 +++++ .../Implementation/GrpcClientDiagnosticListener.cs | 5 +++++ .../OpenTelemetry.Instrumentation.GrpcNetClient.csproj | 1 + .../Implementation/HttpHandlerDiagnosticListener.cs | 5 +++++ .../Implementation/HttpHandlerMetricsDiagnosticListener.cs | 5 +++++ .../OpenTelemetry.Instrumentation.Http.csproj | 1 + .../Implementation/SqlClientDiagnosticListener.cs | 5 +++++ .../OpenTelemetry.Instrumentation.SqlClient.csproj | 1 + 8 files changed, 28 insertions(+) diff --git a/src/OpenTelemetry.Instrumentation.AspNetCore/Implementation/HttpInMetricsListener.cs b/src/OpenTelemetry.Instrumentation.AspNetCore/Implementation/HttpInMetricsListener.cs index 8e688b0343..810225daa2 100644 --- a/src/OpenTelemetry.Instrumentation.AspNetCore/Implementation/HttpInMetricsListener.cs +++ b/src/OpenTelemetry.Instrumentation.AspNetCore/Implementation/HttpInMetricsListener.cs @@ -21,6 +21,7 @@ using Microsoft.AspNetCore.Routing; #endif using OpenTelemetry.Trace; +using static OpenTelemetry.Internal.HttpSemanticConventionHelper; namespace OpenTelemetry.Instrumentation.AspNetCore.Implementation { @@ -34,12 +35,16 @@ internal sealed class HttpInMetricsListener : ListenerHandler private readonly AspNetCoreMetricsInstrumentationOptions options; private readonly Histogram httpServerDuration; + private readonly HttpSemanticConvention httpSemanticConvention; + internal HttpInMetricsListener(string name, Meter meter, AspNetCoreMetricsInstrumentationOptions options) : base(name) { this.meter = meter; this.options = options; this.httpServerDuration = meter.CreateHistogram(HttpServerDurationMetricName, "ms", "Measures the duration of inbound HTTP requests."); + + this.httpSemanticConvention = GetSemanticConventionOptIn(); } public override void OnEventWritten(string name, object payload) diff --git a/src/OpenTelemetry.Instrumentation.GrpcNetClient/Implementation/GrpcClientDiagnosticListener.cs b/src/OpenTelemetry.Instrumentation.GrpcNetClient/Implementation/GrpcClientDiagnosticListener.cs index 73b7cd98f6..04183129d1 100644 --- a/src/OpenTelemetry.Instrumentation.GrpcNetClient/Implementation/GrpcClientDiagnosticListener.cs +++ b/src/OpenTelemetry.Instrumentation.GrpcNetClient/Implementation/GrpcClientDiagnosticListener.cs @@ -19,6 +19,7 @@ using OpenTelemetry.Context.Propagation; using OpenTelemetry.Instrumentation.Http; using OpenTelemetry.Trace; +using static OpenTelemetry.Internal.HttpSemanticConventionHelper; namespace OpenTelemetry.Instrumentation.GrpcNetClient.Implementation { @@ -36,10 +37,14 @@ internal sealed class GrpcClientDiagnosticListener : ListenerHandler private readonly PropertyFetcher startRequestFetcher = new("Request"); private readonly PropertyFetcher stopRequestFetcher = new("Response"); + private readonly HttpSemanticConvention httpSemanticConvention; + public GrpcClientDiagnosticListener(GrpcClientInstrumentationOptions options) : base("Grpc.Net.Client") { this.options = options; + + this.httpSemanticConvention = GetSemanticConventionOptIn(); } public override void OnEventWritten(string name, object payload) diff --git a/src/OpenTelemetry.Instrumentation.GrpcNetClient/OpenTelemetry.Instrumentation.GrpcNetClient.csproj b/src/OpenTelemetry.Instrumentation.GrpcNetClient/OpenTelemetry.Instrumentation.GrpcNetClient.csproj index 08a0391110..11ef412972 100644 --- a/src/OpenTelemetry.Instrumentation.GrpcNetClient/OpenTelemetry.Instrumentation.GrpcNetClient.csproj +++ b/src/OpenTelemetry.Instrumentation.GrpcNetClient/OpenTelemetry.Instrumentation.GrpcNetClient.csproj @@ -13,6 +13,7 @@ + diff --git a/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpHandlerDiagnosticListener.cs b/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpHandlerDiagnosticListener.cs index fa10137333..c0709fcd75 100644 --- a/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpHandlerDiagnosticListener.cs +++ b/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpHandlerDiagnosticListener.cs @@ -21,6 +21,7 @@ using System.Reflection; using OpenTelemetry.Context.Propagation; using OpenTelemetry.Trace; +using static OpenTelemetry.Internal.HttpSemanticConventionHelper; namespace OpenTelemetry.Instrumentation.Http.Implementation { @@ -45,6 +46,8 @@ internal sealed class HttpHandlerDiagnosticListener : ListenerHandler private readonly PropertyFetcher stopRequestStatusFetcher = new("RequestTaskStatus"); private readonly HttpClientInstrumentationOptions options; + private readonly HttpSemanticConvention httpSemanticConvention; + static HttpHandlerDiagnosticListener() { try @@ -61,6 +64,8 @@ public HttpHandlerDiagnosticListener(HttpClientInstrumentationOptions options) : base("HttpHandlerDiagnosticListener") { this.options = options; + + this.httpSemanticConvention = GetSemanticConventionOptIn(); } public override void OnEventWritten(string name, object payload) diff --git a/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpHandlerMetricsDiagnosticListener.cs b/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpHandlerMetricsDiagnosticListener.cs index 4fc5a4f982..b39806232a 100644 --- a/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpHandlerMetricsDiagnosticListener.cs +++ b/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpHandlerMetricsDiagnosticListener.cs @@ -20,6 +20,7 @@ using System.Net.Http; #endif using OpenTelemetry.Trace; +using static OpenTelemetry.Internal.HttpSemanticConventionHelper; namespace OpenTelemetry.Instrumentation.Http.Implementation { @@ -31,10 +32,14 @@ internal sealed class HttpHandlerMetricsDiagnosticListener : ListenerHandler private readonly PropertyFetcher stopRequestFetcher = new("Request"); private readonly Histogram httpClientDuration; + private readonly HttpSemanticConvention httpSemanticConvention; + public HttpHandlerMetricsDiagnosticListener(string name, Meter meter) : base(name) { this.httpClientDuration = meter.CreateHistogram("http.client.duration", "ms", "Measures the duration of outbound HTTP requests."); + + this.httpSemanticConvention = GetSemanticConventionOptIn(); } public override void OnEventWritten(string name, object payload) diff --git a/src/OpenTelemetry.Instrumentation.Http/OpenTelemetry.Instrumentation.Http.csproj b/src/OpenTelemetry.Instrumentation.Http/OpenTelemetry.Instrumentation.Http.csproj index ff3eece862..23a8c183a2 100644 --- a/src/OpenTelemetry.Instrumentation.Http/OpenTelemetry.Instrumentation.Http.csproj +++ b/src/OpenTelemetry.Instrumentation.Http/OpenTelemetry.Instrumentation.Http.csproj @@ -13,6 +13,7 @@ + diff --git a/src/OpenTelemetry.Instrumentation.SqlClient/Implementation/SqlClientDiagnosticListener.cs b/src/OpenTelemetry.Instrumentation.SqlClient/Implementation/SqlClientDiagnosticListener.cs index 8849f218b7..fe17f8e907 100644 --- a/src/OpenTelemetry.Instrumentation.SqlClient/Implementation/SqlClientDiagnosticListener.cs +++ b/src/OpenTelemetry.Instrumentation.SqlClient/Implementation/SqlClientDiagnosticListener.cs @@ -17,6 +17,7 @@ using System.Data; using System.Diagnostics; using OpenTelemetry.Trace; +using static OpenTelemetry.Internal.HttpSemanticConventionHelper; namespace OpenTelemetry.Instrumentation.SqlClient.Implementation { @@ -40,10 +41,14 @@ internal sealed class SqlClientDiagnosticListener : ListenerHandler private readonly PropertyFetcher exceptionFetcher = new("Exception"); private readonly SqlClientInstrumentationOptions options; + private readonly HttpSemanticConvention httpSemanticConvention; + public SqlClientDiagnosticListener(string sourceName, SqlClientInstrumentationOptions options) : base(sourceName) { this.options = options ?? new SqlClientInstrumentationOptions(); + + this.httpSemanticConvention = GetSemanticConventionOptIn(); } public override bool SupportsNullActivity => true; diff --git a/src/OpenTelemetry.Instrumentation.SqlClient/OpenTelemetry.Instrumentation.SqlClient.csproj b/src/OpenTelemetry.Instrumentation.SqlClient/OpenTelemetry.Instrumentation.SqlClient.csproj index 186e71373d..9a47a00608 100644 --- a/src/OpenTelemetry.Instrumentation.SqlClient/OpenTelemetry.Instrumentation.SqlClient.csproj +++ b/src/OpenTelemetry.Instrumentation.SqlClient/OpenTelemetry.Instrumentation.SqlClient.csproj @@ -13,6 +13,7 @@ +