pub struct TracerProvider { /* private fields */ }
Expand description
Creator and registry of named Tracer
instances.
TracerProvider
is a container holding pointers to SpanProcessor
and other components.
Cloning a TracerProvider
instance and dropping it will not stop span processing. To stop span processing, users
must either call the shutdown
method explicitly or allow the last reference to the TracerProvider
to be dropped. When the last reference is dropped, the shutdown process will be automatically triggered
to ensure proper cleanup.
Implementations§
Source§impl TracerProvider
impl TracerProvider
Sourcepub fn builder() -> Builder
pub fn builder() -> Builder
Create a new TracerProvider
builder.
Sourcepub fn force_flush(&self) -> Vec<Result<(), TraceError>>
pub fn force_flush(&self) -> Vec<Result<(), TraceError>>
Force flush all remaining spans in span processors and return results.
§Examples
use opentelemetry::global;
use opentelemetry_sdk::trace::TracerProvider;
fn init_tracing() -> TracerProvider {
let provider = TracerProvider::default();
// Set provider to be used as global tracer provider
let _ = global::set_tracer_provider(provider.clone());
provider
}
fn main() {
let provider = init_tracing();
// create spans..
// force all spans to flush
for result in provider.force_flush() {
if let Err(err) = result {
// .. handle flush error
}
}
// create more spans..
// dropping provider and shutting down global provider ensure all
// remaining spans are exported
drop(provider);
global::shutdown_tracer_provider();
}
Sourcepub fn shutdown(&self) -> Result<(), TraceError>
pub fn shutdown(&self) -> Result<(), TraceError>
Shuts down the current TracerProvider
.
Note that shut down doesn’t means the TracerProvider has dropped
Trait Implementations§
Source§impl Clone for TracerProvider
impl Clone for TracerProvider
Source§fn clone(&self) -> TracerProvider
fn clone(&self) -> TracerProvider
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl Debug for TracerProvider
impl Debug for TracerProvider
Source§impl Default for TracerProvider
impl Default for TracerProvider
Source§fn default() -> TracerProvider
fn default() -> TracerProvider
Returns the “default value” for a type. Read more
Source§impl TracerProvider for TracerProvider
impl TracerProvider for TracerProvider
Source§fn tracer(
&self,
name: impl Into<Cow<'static, str>>,
) -> <TracerProvider as TracerProvider>::Tracer
fn tracer( &self, name: impl Into<Cow<'static, str>>, ) -> <TracerProvider as TracerProvider>::Tracer
Returns a new tracer with the given name. Read more
Source§fn tracer_with_scope(
&self,
scope: InstrumentationScope,
) -> <TracerProvider as TracerProvider>::Tracer
fn tracer_with_scope( &self, scope: InstrumentationScope, ) -> <TracerProvider as TracerProvider>::Tracer
Returns a new versioned tracer with the given instrumentation scope. Read more
Auto Trait Implementations§
impl Freeze for TracerProvider
impl !RefUnwindSafe for TracerProvider
impl Send for TracerProvider
impl Sync for TracerProvider
impl Unpin for TracerProvider
impl !UnwindSafe for TracerProvider
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
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T
in a tonic::Request
Source§impl<S, T, P> ObjectSafeTracerProvider for P
impl<S, T, P> ObjectSafeTracerProvider for P
Source§fn boxed_tracer(
&self,
scope: InstrumentationScope,
) -> Box<dyn ObjectSafeTracer + Sync + Send>
fn boxed_tracer( &self, scope: InstrumentationScope, ) -> Box<dyn ObjectSafeTracer + Sync + Send>
Return a versioned boxed tracer