-
Notifications
You must be signed in to change notification settings - Fork 488
/
Copy pathtrace.rs
105 lines (92 loc) · 3.75 KB
/
trace.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
use criterion::{criterion_group, criterion_main, Criterion};
use futures_util::future::BoxFuture;
use opentelemetry::{
trace::{Span, Tracer, TracerProvider},
KeyValue,
};
use opentelemetry_sdk::{
export::trace::{ExportResult, SpanData, SpanExporter},
trace as sdktrace,
};
#[cfg(not(target_os = "windows"))]
use pprof::criterion::{Output, PProfProfiler};
fn criterion_benchmark(c: &mut Criterion) {
trace_benchmark_group(c, "start-end-span", |tracer| tracer.start("foo").end());
trace_benchmark_group(c, "start-end-span-4-attrs", |tracer| {
let mut span = tracer.start("foo");
span.set_attribute(KeyValue::new("key1", false));
span.set_attribute(KeyValue::new("key2", "hello"));
span.set_attribute(KeyValue::new("key4", 123.456));
span.end();
});
trace_benchmark_group(c, "start-end-span-8-attrs", |tracer| {
let mut span = tracer.start("foo");
span.set_attribute(KeyValue::new("key1", false));
span.set_attribute(KeyValue::new("key2", "hello"));
span.set_attribute(KeyValue::new("key4", 123.456));
span.set_attribute(KeyValue::new("key11", false));
span.set_attribute(KeyValue::new("key12", "hello"));
span.set_attribute(KeyValue::new("key14", 123.456));
span.end();
});
trace_benchmark_group(c, "start-end-span-all-attr-types", |tracer| {
let mut span = tracer.start("foo");
span.set_attribute(KeyValue::new("key1", false));
span.set_attribute(KeyValue::new("key2", "hello"));
span.set_attribute(KeyValue::new("key3", 123));
span.set_attribute(KeyValue::new("key5", 123.456));
span.end();
});
trace_benchmark_group(c, "start-end-span-all-attr-types-2x", |tracer| {
let mut span = tracer.start("foo");
span.set_attribute(KeyValue::new("key1", false));
span.set_attribute(KeyValue::new("key2", "hello"));
span.set_attribute(KeyValue::new("key3", 123));
span.set_attribute(KeyValue::new("key5", 123.456));
span.set_attribute(KeyValue::new("key11", false));
span.set_attribute(KeyValue::new("key12", "hello"));
span.set_attribute(KeyValue::new("key13", 123));
span.set_attribute(KeyValue::new("key15", 123.456));
span.end();
});
}
#[derive(Debug)]
struct VoidExporter;
impl SpanExporter for VoidExporter {
fn export(&mut self, _spans: Vec<SpanData>) -> BoxFuture<'static, ExportResult> {
Box::pin(futures_util::future::ready(Ok(())))
}
}
fn trace_benchmark_group<F: Fn(&sdktrace::Tracer)>(c: &mut Criterion, name: &str, f: F) {
let mut group = c.benchmark_group(name);
group.bench_function("always-sample", |b| {
let provider = sdktrace::TracerProvider::builder()
.with_config(sdktrace::Config::default().with_sampler(sdktrace::Sampler::AlwaysOn))
.with_simple_exporter(VoidExporter)
.build();
let always_sample = provider.tracer("always-sample");
b.iter(|| f(&always_sample));
});
group.bench_function("never-sample", |b| {
let provider = sdktrace::TracerProvider::builder()
.with_config(sdktrace::Config::default().with_sampler(sdktrace::Sampler::AlwaysOff))
.with_simple_exporter(VoidExporter)
.build();
let never_sample = provider.tracer("never-sample");
b.iter(|| f(&never_sample));
});
group.finish();
}
#[cfg(not(target_os = "windows"))]
criterion_group! {
name = benches;
config = Criterion::default().with_profiler(PProfProfiler::new(100, Output::Flamegraph(None)));
targets = criterion_benchmark
}
#[cfg(target_os = "windows")]
criterion_group! {
name = benches;
config = Criterion::default();
targets = criterion_benchmark
}
criterion_main!(benches);