From bb2a9b50815c4e35bb68930a4b55ecae1828b704 Mon Sep 17 00:00:00 2001 From: Sascha Grunert Date: Mon, 17 Oct 2022 09:54:13 +0200 Subject: [PATCH] Manually add OTEL context to both root spans According to https://github.com/open-telemetry/opentelemetry-rust/issues/888#issuecomment-1280052833, this works around the issue where the root span is missing from the traces. Signed-off-by: Sascha Grunert --- conmon-rs/server/src/server.rs | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/conmon-rs/server/src/server.rs b/conmon-rs/server/src/server.rs index 8a12a11092..964678151c 100644 --- a/conmon-rs/server/src/server.rs +++ b/conmon-rs/server/src/server.rs @@ -22,6 +22,7 @@ use nix::{ sys::signal::Signal, unistd::{fork, ForkResult}, }; +use opentelemetry::trace::FutureExt as OpenTelemetryFutureExt; use std::{fs::File, io::Write, path::Path, process, str::FromStr, sync::Arc}; use tokio::{ fs, @@ -32,6 +33,7 @@ use tokio::{ }; use tokio_util::compat::TokioAsyncReadCompatExt; use tracing::{debug, debug_span, info, Instrument}; +use tracing_opentelemetry::OpenTelemetrySpanExt; use tracing_subscriber::{filter::LevelFilter, layer::SubscriberExt, prelude::*}; use twoparty::VatNetwork; @@ -162,11 +164,15 @@ impl Server { let (shutdown_tx, shutdown_rx) = oneshot::channel(); let socket = self.config().socket(); let reaper = self.reaper.clone(); + + let signal_handler_span = debug_span!("signal_handler"); task::spawn( Self::start_signal_handler(reaper, socket, shutdown_tx) - .instrument(debug_span!("signal_handler")), + .with_context(signal_handler_span.context()) + .instrument(signal_handler_span), ); + let backend_span = debug_span!("backend"); task::spawn_blocking(move || { Handle::current().block_on( async { @@ -174,7 +180,8 @@ impl Server { .run_until(self.start_backend(shutdown_rx)) .await } - .instrument(debug_span!("backend")), + .with_context(backend_span.context()) + .instrument(backend_span), ) }) .await?