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 Subscriber 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 subscriber/layer 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 verbosethanLevel::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