Struct TracingLayer
pub struct TracingLayer;
Expand description
Add tracing for every operation.
§Examples
§Basic Setup
let _ = Operator::new(services::Memory::default())?
.layer(TracingLayer)
.finish();
Ok(())
§Real usage
use opentelemetry::trace::TracerProvider;
let tracer_provider = opentelemetry_otlp::new_pipeline()
.tracing()
.with_exporter(opentelemetry_otlp::new_exporter().tonic())
.with_trace_config(trace::Config::default().with_resource(Resource::new(vec![
KeyValue::new("service.name", "opendal_example"),
])))
.install_simple()?;
let tracer = tracer_provider.tracer("opendal_tracer");
let opentelemetry = tracing_opentelemetry::layer().with_tracer(tracer);
tracing_subscriber::registry()
.with(EnvFilter::from_default_env())
.with(opentelemetry)
.try_init()?;
{
let runtime = tokio::runtime::Runtime::new()?;
runtime.block_on(async {
let root = tracing::span!(tracing::Level::INFO, "app_start", work_units = 2);
let _enter = root.enter();
let _ = dotenvy::dotenv();
let op = Operator::new(services::Memory::default())?
.layer(TracingLayer)
.finish();
op.write("test", "0".repeat(16 * 1024 * 1024).into_bytes())
.await?;
op.stat("test").await?;
op.read("test").await?;
Ok::<(), opendal::Error>(())
})?;
}
// Shut down the current tracer provider.
// This will invoke the shutdown method on all span processors.
// span processors should export remaining spans before return.
opentelemetry::global::shutdown_tracer_provider();
Ok(())
§Output
OpenDAL is using tracing
for tracing internally.
To enable tracing output, please init one of the subscribers that tracing
supports.
For example:
let my_subscriber = FooSubscriber::new();
tracing::subscriber::set_global_default(my_subscriber).expect("setting tracing default failed");
For real-world usage, please take a look at tracing-opentelemetry
.
Trait Implementations§
§impl<A> Layer<A> for TracingLayerwhere
A: Access,
impl<A> Layer<A> for TracingLayerwhere
A: Access,
§type LayeredAccess = TracingAccessor<A>
type LayeredAccess = TracingAccessor<A>
The layered accessor that returned by this layer.
§fn layer(&self, inner: A) -> <TracingLayer as Layer<A>>::LayeredAccess
fn layer(&self, inner: A) -> <TracingLayer as Layer<A>>::LayeredAccess
Intercept the operations on the underlying storage.
Auto Trait Implementations§
impl Freeze for TracingLayer
impl RefUnwindSafe for TracingLayer
impl Send for TracingLayer
impl Sync for TracingLayer
impl Unpin for TracingLayer
impl UnwindSafe for TracingLayer
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
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§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<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