7 releases
0.8.0 | Nov 18, 2024 |
---|---|
0.7.4 | Oct 27, 2024 |
0.7.3 | Sep 23, 2024 |
0.7.2 | Aug 16, 2024 |
0.6.8 | Jul 16, 2024 |
#636 in Debugging
8,871 downloads per month
185KB
4K
SLoC
fastrace-opentelemetry
OpenTelemetry reporter for fastrace
.
Dependencies
[dependencies]
fastrace = "0.7"
fastrace-opentelemetry = "0.7"
Setup OpenTelemetry Collector
Start OpenTelemetry Collector with Jaeger and Zipkin receivers:
docker compose -f examples/docker-compose.yaml up
Then, run the synchronous example:
cargo run --example synchronous
Jaeger UI is available on http://127.0.0.1:16686/
Zipkin UI is available on http://127.0.0.1:9411/
Report to OpenTelemetry Collector
use std::borrow::Cow;
use std::time::Duration;
use fastrace::collector::Config;
use fastrace::prelude::*;
use fastrace_opentelemetry::OpenTelemetryReporter;
use opentelemetry_otlp::ExportConfig;
use opentelemetry_otlp::Protocol;
use opentelemetry_otlp::SpanExporter;
use opentelemetry_otlp::TonicConfig;
use opentelemetry::trace::SpanKind;
use opentelemetry_sdk::Resource;
use opentelemetry::KeyValue;
use opentelemetry::InstrumentationScope;
use opentelemetry_otlp::WithExportConfig;
// Initialize reporter
let reporter = OpenTelemetryReporter::new(
SpanExporter::builder()
.with_tonic()
.with_endpoint("http://127.0.0.1:4317".to_string())
.with_protocol(opentelemetry_otlp::Protocol::Grpc)
.with_timeout(Duration::from_secs(
opentelemetry_otlp::OTEL_EXPORTER_OTLP_TIMEOUT_DEFAULT,
))
.build()
.expect("initialize oltp exporter"),
SpanKind::Server,
Cow::Owned(Resource::new([KeyValue::new("service.name", "asynchronous")])),
InstrumentationScope::builder("example-crate").with_version(env!("CARGO_PKG_VERSION")).build(),
);
fastrace::set_reporter(reporter, Config::default());
{
// Start tracing
let root = Span::root("root", SpanContext::random());
}
fastrace::flush()
Dependencies
~3–8.5MB
~75K SLoC