Skip to content

Commit

Permalink
Use released versions + gate bethind tracing feature flag
Browse files Browse the repository at this point in the history
  • Loading branch information
maximebedard committed Dec 5, 2023
1 parent e640051 commit efb0426
Show file tree
Hide file tree
Showing 4 changed files with 44 additions and 27 deletions.
6 changes: 3 additions & 3 deletions examples/tracing-grpc/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,9 @@ name = "grpc-client"
path = "src/client.rs"

[dependencies]
opentelemetry = { path = "../../opentelemetry" }
opentelemetry_sdk = { path = "../../opentelemetry-sdk", features = ["rt-tokio"] }
opentelemetry-jaeger = { path = "../../opentelemetry-jaeger", features = ["rt-tokio"] }
opentelemetry = { version = "0.21" }
opentelemetry_sdk = { version = "0.21", features = ["rt-tokio"] }
opentelemetry-jaeger = { version = "0.20", features = ["rt-tokio"] }
prost = "0.11"
tokio = { version = "1.28", features = ["full"] }
tonic = "0.9.2"
Expand Down
9 changes: 5 additions & 4 deletions opentelemetry-appender-tracing/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -11,17 +11,18 @@ license = "Apache-2.0"
rust-version = "1.65"

[dependencies]
opentelemetry = { path = "../opentelemetry", features = ["logs"] }
opentelemetry_sdk = { path = "../opentelemetry-sdk", features = ["logs"] }
opentelemetry = { version = "0.21", features = ["logs"] }
opentelemetry_sdk = { version = "0.21", features = ["logs"] }
tracing = { version = "0.1", default-features = false, features = ["std"] }
tracing-opentelemetry = "0.22"
tracing-opentelemetry = { version = "0.22", optional = true }
tracing-core = "0.1.31"
tracing-subscriber = { version = "0.3.0", default-features = false, features = ["registry", "std"] }
once_cell = "1.13.0"

[dev-dependencies]
opentelemetry-stdout = { path = "../opentelemetry-stdout", features = ["logs"] }
opentelemetry-stdout = { version = "0.2", features = ["logs"] }

[features]
logs_level_enabled = ["opentelemetry/logs_level_enabled", "opentelemetry_sdk/logs_level_enabled"]
tracing = ["tracing-opentelemetry"]
default = ["logs_level_enabled"]
2 changes: 1 addition & 1 deletion opentelemetry-appender-tracing/examples/basic.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ use opentelemetry_sdk::{
logs::{Config, LoggerProvider},
Resource,
};
use tracing::error;
use tracing::{error, info, info_span};
use tracing_subscriber::prelude::*;

fn main() {
Expand Down
54 changes: 35 additions & 19 deletions opentelemetry-appender-tracing/src/layer.rs
Original file line number Diff line number Diff line change
@@ -1,10 +1,6 @@
use opentelemetry::{
logs::{LogRecord, Logger, LoggerProvider, Severity, TraceContext},
trace::{SpanContext, TraceFlags, TraceState},
};
use opentelemetry::logs::{LogRecord, Logger, LoggerProvider, Severity};
use std::borrow::Cow;
use tracing_core::{Level, Subscriber};
use tracing_opentelemetry::OtelData;
use tracing_subscriber::{registry::LookupSpan, Layer};

const INSTRUMENTATION_LIBRARY_NAME: &str = "opentelemetry-appender-tracing";
Expand Down Expand Up @@ -98,26 +94,19 @@ where
P: LoggerProvider<Logger = L> + Send + Sync + 'static,
L: Logger + Send + Sync + 'static,
{
fn on_event(&self, event: &tracing::Event<'_>, ctx: tracing_subscriber::layer::Context<'_, S>) {
fn on_event(
&self,
event: &tracing::Event<'_>,
_ctx: tracing_subscriber::layer::Context<'_, S>,
) {
let meta = event.metadata();
let mut log_record: LogRecord = LogRecord::default();
log_record.severity_number = Some(severity_of_level(meta.level()));
log_record.severity_text = Some(meta.level().to_string().into());

// Extract the trace_id & span_id from the opentelemetry extension.
if let Some((trace_id, span_id)) = ctx.lookup_current().and_then(|span| {
span.extensions()
.get::<OtelData>()
.and_then(|ext| ext.builder.trace_id.zip(ext.builder.span_id))
}) {
log_record.trace_context = Some(TraceContext::from(&SpanContext::new(
trace_id,
span_id,
TraceFlags::default(),
false,
TraceState::default(),
)));
}
#[cfg(feature = "tracing")]
inject_trace_context(&mut log_record, &_ctx);

// add the `name` metadata to attributes
// TBD - Propose this to be part of log_record metadata.
Expand Down Expand Up @@ -146,6 +135,33 @@ where
}
}

#[cfg(feature = "tracing")]
fn inject_trace_context<S>(
log_record: &mut LogRecord,
ctx: &tracing_subscriber::layer::Context<'_, S>,
) where
S: Subscriber + for<'a> LookupSpan<'a>,
{
use opentelemetry::{
logs::TraceContext,
trace::{SpanContext, TraceFlags, TraceState},
};

if let Some((trace_id, span_id)) = ctx.lookup_current().and_then(|span| {
span.extensions()
.get::<tracing_opentelemetry::OtelData>()
.and_then(|ext| ext.builder.trace_id.zip(ext.builder.span_id))
}) {
log_record.trace_context = Some(TraceContext::from(&SpanContext::new(
trace_id,
span_id,
TraceFlags::default(),
false,
TraceState::default(),
)));
}
}

const fn severity_of_level(level: &Level) -> Severity {
match *level {
Level::TRACE => Severity::Trace,
Expand Down

0 comments on commit efb0426

Please sign in to comment.