Struct tracing_opentelemetry::OpenTelemetryLayer
source · [−]pub struct OpenTelemetryLayer<S, T> { /* private fields */ }
Expand description
An OpenTelemetry propagation layer for use in a project that uses tracing.
Implementations
sourceimpl<S, T> OpenTelemetryLayer<S, T>where
S: Subscriber + for<'span> LookupSpan<'span>,
T: Tracer + PreSampledTracer + 'static,
impl<S, T> OpenTelemetryLayer<S, T>where
S: Subscriber + for<'span> LookupSpan<'span>,
T: Tracer + PreSampledTracer + 'static,
sourcepub fn new(tracer: T) -> Self
pub fn new(tracer: T) -> Self
Set the Tracer
that this layer will use to produce and track
OpenTelemetry Span
s.
Examples
use tracing_opentelemetry::OpenTelemetryLayer;
use tracing_subscriber::layer::SubscriberExt;
use tracing_subscriber::Registry;
// Create a jaeger exporter pipeline for a `trace_demo` service.
let tracer = opentelemetry_jaeger::new_pipeline()
.with_service_name("trace_demo")
.install_simple()
.expect("Error initializing Jaeger exporter");
// Create a layer with the configured tracer
let otel_layer = OpenTelemetryLayer::new(tracer);
// Use the tracing subscriber `Registry`, or any other subscriber
// that impls `LookupSpan`
let subscriber = Registry::default().with(otel_layer);
sourcepub fn with_tracer<Tracer>(self, tracer: Tracer) -> OpenTelemetryLayer<S, Tracer>where
Tracer: Tracer + PreSampledTracer + 'static,
pub fn with_tracer<Tracer>(self, tracer: Tracer) -> OpenTelemetryLayer<S, Tracer>where
Tracer: Tracer + PreSampledTracer + 'static,
Set the Tracer
that this layer will use to produce and track
OpenTelemetry Span
s.
Examples
use tracing_subscriber::layer::SubscriberExt;
use tracing_subscriber::Registry;
// Create a jaeger exporter pipeline for a `trace_demo` service.
let tracer = opentelemetry_jaeger::new_pipeline()
.with_service_name("trace_demo")
.install_simple()
.expect("Error initializing Jaeger exporter");
// Create a layer with the configured tracer
let otel_layer = tracing_opentelemetry::layer().with_tracer(tracer);
// Use the tracing subscriber `Registry`, or any other subscriber
// that impls `LookupSpan`
let subscriber = Registry::default().with(otel_layer);
sourcepub fn with_tracked_inactivity(self, tracked_inactivity: bool) -> Self
pub fn with_tracked_inactivity(self, tracked_inactivity: bool) -> Self
Sets whether or not spans metadata should include the busy time (total time for which it was entered), and idle time (total time the span existed but was not entered).
Trait Implementations
sourceimpl<S> Default for OpenTelemetryLayer<S, NoopTracer>where
S: Subscriber + for<'span> LookupSpan<'span>,
impl<S> Default for OpenTelemetryLayer<S, NoopTracer>where
S: Subscriber + for<'span> LookupSpan<'span>,
sourceimpl<S, T> Layer<S> for OpenTelemetryLayer<S, T>where
S: Subscriber + for<'span> LookupSpan<'span>,
T: Tracer + PreSampledTracer + 'static,
impl<S, T> Layer<S> for OpenTelemetryLayer<S, T>where
S: Subscriber + for<'span> LookupSpan<'span>,
T: Tracer + PreSampledTracer + 'static,
sourcefn new_span(&self, attrs: &Attributes<'_>, id: &Id, ctx: Context<'_, S>)
fn new_span(&self, attrs: &Attributes<'_>, id: &Id, ctx: Context<'_, S>)
Creates an OpenTelemetry Span
for the corresponding tracing Span
.
sourcefn on_record(&self, id: &Id, values: &Record<'_>, ctx: Context<'_, S>)
fn on_record(&self, id: &Id, values: &Record<'_>, ctx: Context<'_, S>)
Record OpenTelemetry attributes
for the given values.
sourcefn on_enter(&self, id: &Id, ctx: Context<'_, S>)
fn on_enter(&self, id: &Id, ctx: Context<'_, S>)
Notifies this layer that a span with the given ID was entered.
sourcefn on_exit(&self, id: &Id, ctx: Context<'_, S>)
fn on_exit(&self, id: &Id, ctx: Context<'_, S>)
Notifies this layer that the span with the given ID was exited.
sourcefn on_follows_from(&self, id: &Id, follows: &Id, ctx: Context<'_, S>)
fn on_follows_from(&self, id: &Id, follows: &Id, ctx: Context<'_, S>)
Notifies this layer that a span with the ID
span
recorded that it
follows from the span with the ID follows
. Read moresourcefn register_callsite(&self, metadata: &'static Metadata<'static>) -> Interest
fn register_callsite(&self, metadata: &'static Metadata<'static>) -> Interest
Registers a new callsite with this layer, returning whether or not
the layer is interested in being notified about the callsite, similarly
to
Subscriber::register_callsite
. Read moresourcefn enabled(&self, metadata: &Metadata<'_>, ctx: Context<'_, S>) -> bool
fn enabled(&self, metadata: &Metadata<'_>, ctx: Context<'_, S>) -> bool
Returns
true
if this layer is interested in a span or event with the
given metadata
in the current Context
, similarly to
Subscriber::enabled
. Read moresourcefn on_id_change(&self, _old: &Id, _new: &Id, _ctx: Context<'_, S>)
fn on_id_change(&self, _old: &Id, _new: &Id, _ctx: Context<'_, S>)
Notifies this layer that a span ID has been cloned, and that the
subscriber returned a different ID. Read more
sourcefn and_then<L>(self, layer: L) -> Layered<L, Self, S>where
L: Layer<S>,
fn and_then<L>(self, layer: L) -> Layered<L, Self, S>where
L: Layer<S>,
Composes this layer around the given
Layer
, returning a Layered
struct implementing Layer
. Read moresourcefn with_subscriber(self, inner: S) -> Layered<Self, S, S>
fn with_subscriber(self, inner: S) -> Layered<Self, S, S>
Composes this
Layer
with the given Subscriber
, returning a
Layered
struct that implements Subscriber
. Read moreAuto Trait Implementations
impl<S, T> RefUnwindSafe for OpenTelemetryLayer<S, T>where
S: RefUnwindSafe,
T: RefUnwindSafe,
impl<S, T> Send for OpenTelemetryLayer<S, T>where
S: Send,
T: Send,
impl<S, T> Sync for OpenTelemetryLayer<S, T>where
S: Sync,
T: Sync,
impl<S, T> Unpin for OpenTelemetryLayer<S, T>where
S: Unpin,
T: Unpin,
impl<S, T> UnwindSafe for OpenTelemetryLayer<S, T>where
S: UnwindSafe,
T: UnwindSafe,
Blanket Implementations
sourceimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more