pub struct NonBlocking { /* private fields */ }
Expand description
A non-blocking writer.
While the line between โblockingโ and โnon-blockingโ IO is fuzzy, writing to a file is typically
considered to be a blocking operation. For an application whose Collector
writes spans and events
as they are emitted, an application might find the latency profile to be unacceptable.
NonBlocking
moves the writing out of an applicationโs data path by sending spans and events
to a dedicated logging thread.
This struct implements MakeWriter
from the tracing-subscriber
crate. Therefore, it can be used with the tracing_subscriber::fmt
module
or with any other collector/subscriber implementation that uses the MakeWriter
trait.
Implementationsยง
Sourceยงimpl NonBlocking
impl NonBlocking
Sourcepub fn new<T: Write + Send + 'static>(writer: T) -> (NonBlocking, WorkerGuard)
pub fn new<T: Write + Send + 'static>(writer: T) -> (NonBlocking, WorkerGuard)
Returns a new NonBlocking
writer wrapping the provided writer
.
The returned NonBlocking
writer will have the default configuration values.
Other configurations can be specified using the builder interface.
Sourcepub fn error_counter(&self) -> ErrorCounter
pub fn error_counter(&self) -> ErrorCounter
Returns a counter for the number of times logs where dropped. This will always return zero if
NonBlocking
is not lossy.
Trait Implementationsยง
Sourceยงimpl Clone for NonBlocking
impl Clone for NonBlocking
1.0.0 ยท Sourceยงfn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSourceยงimpl Debug for NonBlocking
impl Debug for NonBlocking
Sourceยงimpl<'a> MakeWriter<'a> for NonBlocking
impl<'a> MakeWriter<'a> for NonBlocking
Sourceยงtype Writer = NonBlocking
type Writer = NonBlocking
io::Write
implementation returned by make_writer
.Sourceยงimpl Write for NonBlocking
impl Write for NonBlocking
Sourceยงfn write(&mut self, buf: &[u8]) -> Result<usize>
fn write(&mut self, buf: &[u8]) -> Result<usize>
Sourceยงfn flush(&mut self) -> Result<()>
fn flush(&mut self) -> Result<()>
Sourceยงfn write_all(&mut self, buf: &[u8]) -> Result<()>
fn write_all(&mut self, buf: &[u8]) -> Result<()>
Sourceยงfn is_write_vectored(&self) -> bool
fn is_write_vectored(&self) -> bool
can_vector
#69941)Sourceยงfn write_all_vectored(&mut self, bufs: &mut [IoSlice<'_>]) -> Result<(), Error>
fn write_all_vectored(&mut self, bufs: &mut [IoSlice<'_>]) -> Result<(), Error>
write_all_vectored
#70436)Auto Trait Implementationsยง
impl Freeze for NonBlocking
impl RefUnwindSafe for NonBlocking
impl Send for NonBlocking
impl Sync for NonBlocking
impl Unpin for NonBlocking
impl UnwindSafe for NonBlocking
Blanket Implementationsยง
Sourceยงimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Sourceยงfn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Sourceยงimpl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Sourceยงimpl<T> Instrument for T
impl<T> Instrument for T
Sourceยงfn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Sourceยงfn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Sourceยงimpl<'a, M> MakeWriterExt<'a> for Mwhere
M: MakeWriter<'a>,
impl<'a, M> MakeWriterExt<'a> for Mwhere
M: MakeWriter<'a>,
Sourceยงfn with_max_level(self, level: Level) -> WithMaxLevel<Self>where
Self: Sized,
fn with_max_level(self, level: Level) -> WithMaxLevel<Self>where
Self: Sized,
self
and returns a MakeWriter
that will only write output
for events at or below the provided verbosity Level
. For instance,
Level::TRACE
is considered to be _more verbosethan
Level::INFO`. Read moreSourceยงfn with_min_level(self, level: Level) -> WithMinLevel<Self>where
Self: Sized,
fn with_min_level(self, level: Level) -> WithMinLevel<Self>where
Self: Sized,
self
and returns a MakeWriter
that will only write output
for events at or above the provided verbosity Level
. Read moreSourceยงfn with_filter<F>(self, filter: F) -> WithFilter<Self, F>
fn with_filter<F>(self, filter: F) -> WithFilter<Self, F>
self
with a predicate that takes a span or eventโs Metadata
and returns a bool
. The returned MakeWriter
โs
MakeWriter::make_writer_for
method will check the predicate to
determine if a writer should be produced for a given span or event. Read moreSourceยงfn and<B>(self, other: B) -> Tee<Self, B>where
Self: Sized,
B: MakeWriter<'a>,
fn and<B>(self, other: B) -> Tee<Self, B>where
Self: Sized,
B: MakeWriter<'a>,
self
with another type implementing MakeWriter
, returning
a new MakeWriter
that produces writers that write to both
outputs. Read moreSourceยงfn or_else<W, B>(self, other: B) -> OrElse<Self, B>
fn or_else<W, B>(self, other: B) -> OrElse<Self, B>
self
with another type implementing MakeWriter
, returning
a new MakeWriter
that calls other
โs make_writer
if self
โs
make_writer
returns OptionalWriter::none
. Read more