From 3febe7d020af1b24efd731b7a01a5dd944c9d5a6 Mon Sep 17 00:00:00 2001 From: Renaud Chaput Date: Wed, 18 Dec 2024 08:34:20 +0100 Subject: [PATCH] Add OTEL trace & span IDs to logs (#33339) --- config/initializers/opentelemetry.rb | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/config/initializers/opentelemetry.rb b/config/initializers/opentelemetry.rb index 90217139a..0a8d686f6 100644 --- a/config/initializers/opentelemetry.rb +++ b/config/initializers/opentelemetry.rb @@ -76,6 +76,34 @@ if ENV.keys.any? { |name| name.match?(/OTEL_.*_ENDPOINT/) } ) end end + + # This middleware adds the trace_id and span_id to the Rails logging tags for every requests + class TelemetryLoggingMiddleware + def initialize(app) + @app = app + end + + def call(env) + span = OpenTelemetry::Trace.current_span + + unless span.recording? + @app.call(env) + return + end + + span_id = span.context.hex_span_id + trace_id = span.context.hex_trace_id + + Rails.logger.tagged("trace_id=#{trace_id}", "span_id=#{span_id}") do + @app.call(env) + end + end + end + + Rails.application.configure do + config.middleware.insert_before Rails::Rack::Logger, TelemetryLoggingMiddleware + end + end MastodonOTELTracer = OpenTelemetry.tracer_provider.tracer('mastodon')