mirror of
https://github.com/tokio-rs/tokio.git
synced 2025-09-28 12:10:37 +00:00

This branch makes the following changes to `tokio-trace`'s `Span` type: * **Remove manual close API from spans** In practice, there wasn't really a use-case for this, and it complicates the implementation a bit. We can always add it back later. * **Remove generic lifetime from `Span`** Again, there wasn't actually a use-case for spans with metadata that doesn't live for the static lifetime, and it made using `Span`s in other types somewhat inconvenient. It's also possible to implement an alternative API for non-static spans on top of the `tokio-trace-core` primitives. Signed-off-by: Eliza Weisman <eliza@buoyant.io>
153 lines
3.5 KiB
Rust
153 lines
3.5 KiB
Rust
#![feature(test)]
|
|
|
|
#[macro_use]
|
|
extern crate tokio_trace;
|
|
extern crate test;
|
|
use test::Bencher;
|
|
|
|
use std::{
|
|
fmt,
|
|
sync::{Mutex, MutexGuard},
|
|
};
|
|
use tokio_trace::{field, span, Event, Id, Metadata};
|
|
|
|
/// A subscriber that is enabled but otherwise does nothing.
|
|
struct EnabledSubscriber;
|
|
|
|
impl tokio_trace::Subscriber for EnabledSubscriber {
|
|
fn new_span(&self, span: &span::Attributes) -> Id {
|
|
let _ = span;
|
|
Id::from_u64(0)
|
|
}
|
|
|
|
fn event(&self, event: &Event) {
|
|
let _ = event;
|
|
}
|
|
|
|
fn record(&self, span: &Id, values: &span::Record) {
|
|
let _ = (span, values);
|
|
}
|
|
|
|
fn record_follows_from(&self, span: &Id, follows: &Id) {
|
|
let _ = (span, follows);
|
|
}
|
|
|
|
fn enabled(&self, metadata: &Metadata) -> bool {
|
|
let _ = metadata;
|
|
true
|
|
}
|
|
|
|
fn enter(&self, span: &Id) {
|
|
let _ = span;
|
|
}
|
|
|
|
fn exit(&self, span: &Id) {
|
|
let _ = span;
|
|
}
|
|
}
|
|
|
|
/// Simulates a subscriber that records span data.
|
|
struct VisitingSubscriber(Mutex<String>);
|
|
|
|
struct Visitor<'a>(MutexGuard<'a, String>);
|
|
|
|
impl<'a> field::Visit for Visitor<'a> {
|
|
fn record_debug(&mut self, _field: &field::Field, value: &fmt::Debug) {
|
|
use std::fmt::Write;
|
|
let _ = write!(&mut *self.0, "{:?}", value);
|
|
}
|
|
}
|
|
|
|
impl tokio_trace::Subscriber for VisitingSubscriber {
|
|
fn new_span(&self, span: &span::Attributes) -> Id {
|
|
let mut visitor = Visitor(self.0.lock().unwrap());
|
|
span.record(&mut visitor);
|
|
Id::from_u64(0)
|
|
}
|
|
|
|
fn record(&self, _span: &Id, values: &span::Record) {
|
|
let mut visitor = Visitor(self.0.lock().unwrap());
|
|
values.record(&mut visitor);
|
|
}
|
|
|
|
fn event(&self, event: &Event) {
|
|
let mut visitor = Visitor(self.0.lock().unwrap());
|
|
event.record(&mut visitor);
|
|
}
|
|
|
|
fn record_follows_from(&self, span: &Id, follows: &Id) {
|
|
let _ = (span, follows);
|
|
}
|
|
|
|
fn enabled(&self, metadata: &Metadata) -> bool {
|
|
let _ = metadata;
|
|
true
|
|
}
|
|
|
|
fn enter(&self, span: &Id) {
|
|
let _ = span;
|
|
}
|
|
|
|
fn exit(&self, span: &Id) {
|
|
let _ = span;
|
|
}
|
|
}
|
|
|
|
const N_SPANS: usize = 100;
|
|
|
|
#[bench]
|
|
fn span_no_fields(b: &mut Bencher) {
|
|
tokio_trace::subscriber::with_default(EnabledSubscriber, || b.iter(|| span!("span")));
|
|
}
|
|
|
|
#[bench]
|
|
fn enter_span(b: &mut Bencher) {
|
|
tokio_trace::subscriber::with_default(EnabledSubscriber, || {
|
|
b.iter(|| test::black_box(span!("span").enter(|| {})))
|
|
});
|
|
}
|
|
|
|
#[bench]
|
|
fn span_repeatedly(b: &mut Bencher) {
|
|
#[inline]
|
|
fn mk_span(i: u64) -> tokio_trace::Span {
|
|
span!("span", i = i)
|
|
}
|
|
|
|
let n = test::black_box(N_SPANS);
|
|
tokio_trace::subscriber::with_default(EnabledSubscriber, || {
|
|
b.iter(|| (0..n).fold(mk_span(0), |_, i| mk_span(i as u64)))
|
|
});
|
|
}
|
|
|
|
#[bench]
|
|
fn span_with_fields(b: &mut Bencher) {
|
|
tokio_trace::subscriber::with_default(EnabledSubscriber, || {
|
|
b.iter(|| {
|
|
span!(
|
|
"span",
|
|
foo = "foo",
|
|
bar = "bar",
|
|
baz = 3,
|
|
quuux = tokio_trace::field::debug(0.99)
|
|
)
|
|
})
|
|
});
|
|
}
|
|
|
|
#[bench]
|
|
fn span_with_fields_record(b: &mut Bencher) {
|
|
let subscriber = VisitingSubscriber(Mutex::new(String::from("")));
|
|
tokio_trace::subscriber::with_default(subscriber, || {
|
|
b.iter(|| {
|
|
span!(
|
|
"span",
|
|
foo = "foo",
|
|
bar = "bar",
|
|
baz = 3,
|
|
quuux = tokio_trace::field::debug(0.99)
|
|
)
|
|
})
|
|
});
|
|
}
|