Crates.io | tracing-opentelemetry-extra |
lib.rs | tracing-opentelemetry-extra |
version | 0.30.10 |
created_at | 2025-06-21 09:59:03.849594+00 |
updated_at | 2025-08-07 04:20:21.869217+00 |
description | Bootstrap utilities for tracing and OpenTelemetry integration. |
homepage | https://github.com/iamnivekx/tracing-otel-extra/tree/main/crates/tracing-opentelemetry |
repository | https://github.com/iamnivekx/tracing-otel-extra/tree/main/crates/tracing-opentelemetry |
max_upload_size | |
id | 1720681 |
size | 61,093 |
Reference: This crate is mainly organized based on the official tracing-opentelemetry OTLP example.
This crate provides enhanced OpenTelemetry integration for tracing applications. It's based on the tracing-opentelemetry examples and provides a clean, easy-to-use API for setting up OpenTelemetry tracing and metrics.
Add this to your Cargo.toml
:
[dependencies]
tracing-opentelemetry-extra = "0.30.x"
use opentelemetry::KeyValue;
use tracing_opentelemetry_extra::{get_resource, init_tracer_provider, init_meter_provider, OtelGuard};
#[tokio::main]
async fn main() -> anyhow::Result<()> {
// Create resource with service name and attributes
let resource = get_resource(
"my-service",
&[
KeyValue::new("environment", "production"),
KeyValue::new("version", "1.0.0"),
],
);
// Initialize providers
let tracer_provider = init_tracer_provider(&resource, 1.0)?;
let meter_provider = init_meter_provider(&resource, 30)?;
// initialize tracing subscriber with otel layers
// Create guard for automatic cleanup
let _guard = OtelGuard::new(Some(tracer_provider), Some(meter_provider));
// Your application code here...
tracing::info!("Application started");
// Cleanup is handled automatically when the guard is dropped
Ok(())
}
use opentelemetry::KeyValue;
use tracing_opentelemetry_extra::{get_resource, init_tracer_provider, init_meter_provider, init_tracing_subscriber, OtelGuard};
use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt, EnvFilter};
#[tokio::main]
async fn main() -> anyhow::Result<()> {
// Create resource
let service_name = "my-service";
let resource = get_resource(service_name, &[KeyValue::new("environment", "production")]);
// Initialize providers
let tracer_provider = init_tracer_provider(&resource, 1.0)?;
let meter_provider = init_meter_provider(&resource, 30)?;
// Set up tracing subscriber
let env_filter = init_env_filter(&Level::INFO);
// Create guard for cleanup
let _guard = init_tracing_subscriber(
service_name,
env_filter,
vec![Box::new(tracing_subscriber::fmt::layer())],
tracer_provider,
meter_provider,
)?;
// Your application code here...
tracing::info!("Application started with OpenTelemetry");
Ok(())
}
Control the ratio of traces to sample (0.0 to 1.0):
// Sample 50% of traces
let tracer_provider = init_tracer_provider(&resource, 0.5)?;
// Sample all traces
let tracer_provider = init_tracer_provider(&resource, 1.0)?;
Configure the interval for metrics collection:
// Collect metrics every 60 seconds
let meter_provider = init_meter_provider(&resource, 60)?;
Add custom attributes to your service:
let resource = get_resource(
"my-service",
&[
KeyValue::new("environment", "production"),
KeyValue::new("version", "1.0.0"),
KeyValue::new("region", "us-west-2"),
],
);
subscriber
(default): Enables tracing-subscriber integrationSee the examples directory for more detailed usage examples.
Contributions are welcome! Please feel free to submit a Pull Request.
This project is licensed under either of
at your option.