pub struct OpenTelemetryLayer<S, T> { /* private fields */ }Expand description
An OpenTelemetry propagation layer for use in a project that uses tracing.
Implementations§
Source§impl<S, T> OpenTelemetryLayer<S, T>
 
impl<S, T> OpenTelemetryLayer<S, T>
Sourcepub fn new(tracer: T) -> OpenTelemetryLayer<S, T>
 
pub fn new(tracer: T) -> OpenTelemetryLayer<S, T>
Set the Tracer that this layer will use to produce and track
OpenTelemetry Spans.
§Examples
use tracing_opentelemetry::OpenTelemetryLayer;
use tracing_subscriber::layer::SubscriberExt;
use opentelemetry::trace::TracerProvider as _;
use tracing_subscriber::Registry;
// Create an OTLP pipeline exporter for a `trace_demo` service.
let otlp_exporter = opentelemetry_otlp::SpanExporter::builder()
    .with_tonic()
    .build()
    .unwrap();
let tracer = opentelemetry_sdk::trace::SdkTracerProvider::builder()
    .with_simple_exporter(otlp_exporter)
    .build()
    .tracer("trace_demo");
// 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 Spans.
§Examples
use tracing_subscriber::layer::SubscriberExt;
use tracing_subscriber::Registry;
use opentelemetry::trace::TracerProvider;
// Create an OTLP pipeline exporter for a `trace_demo` service.
let otlp_exporter = opentelemetry_otlp::SpanExporter::builder()
    .with_tonic()
    .build()
    .unwrap();
let tracer = opentelemetry_sdk::trace::SdkTracerProvider::builder()
    .with_simple_exporter(otlp_exporter)
    .build()
    .tracer("trace_demo");
// 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_error_fields_to_exceptions(
    self,
    error_fields_to_exceptions: bool,
) -> OpenTelemetryLayer<S, T>
 
pub fn with_error_fields_to_exceptions( self, error_fields_to_exceptions: bool, ) -> OpenTelemetryLayer<S, T>
Sets whether or not span and event metadata should include OpenTelemetry
exception fields such as exception.message and exception.backtrace
when an Error value is recorded. If multiple error values are recorded
on the same span/event, only the most recently recorded error value will
show up under these fields.
These attributes follow the OpenTelemetry semantic conventions for exceptions.
By default, these attributes are recorded.
Note that this only works for (dyn Error + 'static).
See Implementations on Foreign Types of tracing::Value or OpenTelemetryLayer::with_error_events_to_exceptions
Sourcepub fn with_error_events_to_status(
    self,
    error_events_to_status: bool,
) -> OpenTelemetryLayer<S, T>
 
pub fn with_error_events_to_status( self, error_events_to_status: bool, ) -> OpenTelemetryLayer<S, T>
Sets whether or not an event considered for exception mapping (see [OpenTelemetryLayer::with_error_recording])
should be propagated to the span status error description.
By default, these events do set the span status error description.
Sourcepub fn with_error_events_to_exceptions(
    self,
    error_events_to_exceptions: bool,
) -> OpenTelemetryLayer<S, T>
 
pub fn with_error_events_to_exceptions( self, error_events_to_exceptions: bool, ) -> OpenTelemetryLayer<S, T>
Sets whether or not a subset of events following the described schema are mapped to events following the OpenTelemetry semantic conventions for exceptions.
- Only events without a message field (unnamed events) and at least one field with the name error are considered for mapping.
By default, these events are mapped.
Sourcepub fn with_error_records_to_exceptions(
    self,
    error_records_to_exceptions: bool,
) -> OpenTelemetryLayer<S, T>
 
pub fn with_error_records_to_exceptions( self, error_records_to_exceptions: bool, ) -> OpenTelemetryLayer<S, T>
Sets whether or not reporting an Error value on an event will
propagate the OpenTelemetry exception fields such as exception.message
and exception.backtrace to the corresponding span. You do not need to
enable with_exception_fields in order to enable this. If multiple
error values are recorded on the same span/event, only the most recently
recorded error value will show up under these fields.
These attributes follow the OpenTelemetry semantic conventions for exceptions.
By default, these attributes are propagated to the span. Note that this only works for (dyn Error + 'static).
See Implementations on Foreign Types of tracing::Value or OpenTelemetryLayer::with_error_events_to_exceptions
Sourcepub fn with_location(self, location: bool) -> OpenTelemetryLayer<S, T>
 
pub fn with_location(self, location: bool) -> OpenTelemetryLayer<S, T>
Sets whether or not span and event metadata should include OpenTelemetry attributes with location information, such as the file, module and line number.
These attributes follow the OpenTelemetry semantic conventions for source locations.
By default, locations are enabled.
Sourcepub fn with_tracked_inactivity(
    self,
    tracked_inactivity: bool,
) -> OpenTelemetryLayer<S, T>
 
pub fn with_tracked_inactivity( self, tracked_inactivity: bool, ) -> OpenTelemetryLayer<S, T>
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).
By default, inactivity tracking is enabled.
Sourcepub fn with_threads(self, threads: bool) -> OpenTelemetryLayer<S, T>
 
pub fn with_threads(self, threads: bool) -> OpenTelemetryLayer<S, T>
Sets whether or not spans record additional attributes for the thread name and thread ID of the thread they were created on, following the OpenTelemetry semantic conventions for threads.
By default, thread attributes are enabled.
Sourcepub fn with_level(self, level: bool) -> OpenTelemetryLayer<S, T>
 
pub fn with_level(self, level: bool) -> OpenTelemetryLayer<S, T>
Sets whether or not span metadata should include the tracing verbosity level information as a level field.
The level is always added to events, and based on OpenTelemetryLayer::with_error_events_to_status
error-level events will mark the span status as an error.
By default, level information is disabled.
Trait Implementations§
Source§impl<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>,
Source§fn default() -> OpenTelemetryLayer<S, NoopTracer>
 
fn default() -> OpenTelemetryLayer<S, NoopTracer>
Source§impl<S, T> Layer<S> for OpenTelemetryLayer<S, T>
 
impl<S, T> Layer<S> for OpenTelemetryLayer<S, T>
Source§fn on_new_span(&self, attrs: &Attributes<'_>, id: &Id, ctx: Context<'_, S>)
 
fn on_new_span(&self, attrs: &Attributes<'_>, id: &Id, ctx: Context<'_, S>)
Creates an OpenTelemetry Span for the corresponding tracing Span.
Source§fn 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.
Source§fn on_enter(&self, id: &Id, ctx: Context<'_, S>)
 
fn on_enter(&self, id: &Id, ctx: Context<'_, S>)
Source§fn on_exit(&self, id: &Id, ctx: Context<'_, S>)
 
fn on_exit(&self, id: &Id, ctx: Context<'_, S>)
Source§fn on_follows_from(&self, id: &Id, follows: &Id, ctx: Context<'_, S>)
 
fn on_follows_from(&self, id: &Id, follows: &Id, ctx: Context<'_, S>)
span recorded that it
follows from the span with the ID follows.Source§fn on_register_dispatch(&self, subscriber: &Dispatch)
 
fn on_register_dispatch(&self, subscriber: &Dispatch)
Subscriber. Read moreSource§fn register_callsite(&self, metadata: &'static Metadata<'static>) -> Interest
 
fn register_callsite(&self, metadata: &'static Metadata<'static>) -> Interest
Subscriber::register_callsite. Read moreSource§fn enabled(&self, metadata: &Metadata<'_>, ctx: Context<'_, S>) -> bool
 
fn enabled(&self, metadata: &Metadata<'_>, ctx: Context<'_, S>) -> bool
true if this layer is interested in a span or event with the
given metadata in the current Context, similarly to
Subscriber::enabled. Read moreSource§fn on_id_change(&self, _old: &Id, _new: &Id, _ctx: Context<'_, S>)
 
fn on_id_change(&self, _old: &Id, _new: &Id, _ctx: Context<'_, S>)
Source§fn and_then<L>(self, layer: L) -> Layered<L, Self, S>
 
fn and_then<L>(self, layer: L) -> Layered<L, Self, S>
Layer, returning a Layered
struct implementing Layer. Read moreSource§fn with_subscriber(self, inner: S) -> Layered<Self, S>where
    Self: Sized,
 
fn with_subscriber(self, inner: S) -> Layered<Self, S>where
    Self: Sized,
Layer with the given Subscriber, returning a
Layered struct that implements Subscriber. Read moreSource§fn with_filter<F>(self, filter: F) -> Filtered<Self, F, S>
 
fn with_filter<F>(self, filter: F) -> Filtered<Self, F, S>
Auto Trait Implementations§
impl<S, T> Freeze for OpenTelemetryLayer<S, T>where
    T: Freeze,
impl<S, T> RefUnwindSafe for OpenTelemetryLayer<S, T>where
    T: RefUnwindSafe,
    S: RefUnwindSafe,
impl<S, T> Send for OpenTelemetryLayer<S, T>
impl<S, T> Sync for OpenTelemetryLayer<S, T>
impl<S, T> Unpin for OpenTelemetryLayer<S, T>
impl<S, T> UnwindSafe for OpenTelemetryLayer<S, T>where
    T: UnwindSafe,
    S: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> FutureExt for T
 
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
 
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
 
fn with_current_context(self) -> WithContext<Self>
Source§impl<T> FutureExt for T
 
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
 
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
 
fn with_current_context(self) -> WithContext<Self>
Source§impl<T> Instrument for T
 
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
 
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
 
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
 
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
 
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> IntoRequest<T> for T
 
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
 
fn into_request(self) -> Request<T>
T in a tonic::Request