| use criterion::{black_box, criterion_group, criterion_main, Criterion}; |
| use tracing::{info, instrument}; |
| use tracing_subscriber::prelude::*; |
| |
| #[instrument] |
| fn fibonacci(n: u64) -> u64 { |
| if n < 2 { |
| n |
| } else { |
| fibonacci(n - 1) + fibonacci(n - 2) |
| } |
| } |
| |
| fn instrument_benchmark(c: &mut Criterion) { |
| let mut group = c.benchmark_group("instrument"); |
| group.throughput(criterion::Throughput::Elements(3)); |
| |
| group.bench_function("locations_and_args", |b| { |
| let (layer, _guard) = tracing_chrome::ChromeLayerBuilder::new() |
| .include_args(true) |
| .include_locations(true) |
| .writer(std::io::sink()) |
| .build(); |
| let _subscriber = tracing_subscriber::registry().with(layer).set_default(); |
| b.iter(|| black_box(fibonacci(3))); |
| }); |
| group.bench_function("locations", |b| { |
| let (layer, _guard) = tracing_chrome::ChromeLayerBuilder::new() |
| .include_args(false) |
| .include_locations(true) |
| .writer(std::io::sink()) |
| .build(); |
| let _subscriber = tracing_subscriber::registry().with(layer).set_default(); |
| b.iter(|| black_box(fibonacci(3))); |
| }); |
| group.bench_function("minimal", |b| { |
| let (layer, _guard) = tracing_chrome::ChromeLayerBuilder::new() |
| .include_args(false) |
| .include_locations(false) |
| .writer(std::io::sink()) |
| .build(); |
| let _subscriber = tracing_subscriber::registry().with(layer).set_default(); |
| b.iter(|| black_box(fibonacci(3))); |
| }); |
| } |
| |
| fn event_benchmark(c: &mut Criterion) { |
| let mut group = c.benchmark_group("event"); |
| group.throughput(criterion::Throughput::Elements(1)); |
| |
| group.bench_function("locations_and_args", |b| { |
| let (layer, _guard) = tracing_chrome::ChromeLayerBuilder::new() |
| .include_args(true) |
| .include_locations(true) |
| .writer(std::io::sink()) |
| .build(); |
| let _subscriber = tracing_subscriber::registry().with(layer).set_default(); |
| b.iter(|| { |
| info!(arg = 42, "Something Happen"); |
| }); |
| }); |
| group.bench_function("locations", |b| { |
| let (layer, _guard) = tracing_chrome::ChromeLayerBuilder::new() |
| .include_args(false) |
| .include_locations(true) |
| .writer(std::io::sink()) |
| .build(); |
| let _subscriber = tracing_subscriber::registry().with(layer).set_default(); |
| b.iter(|| { |
| info!(arg = 42, "Something Happen"); |
| }); |
| }); |
| group.bench_function("minimal", |b| { |
| let (layer, _guard) = tracing_chrome::ChromeLayerBuilder::new() |
| .include_args(false) |
| .include_locations(false) |
| .writer(std::io::sink()) |
| .build(); |
| let _subscriber = tracing_subscriber::registry().with(layer).set_default(); |
| b.iter(|| { |
| info!(arg = 42, "Something Happen"); |
| }); |
| }); |
| } |
| |
| criterion_group!(benches, instrument_benchmark, event_benchmark); |
| criterion_main!(benches); |