Struct slog_async::Async

source ·
pub struct Async { /* private fields */ }
Expand description

Async drain

Async will send all the logging records to a wrapped drain running in another thread.

Async never returns AsyncError::Full.

Records are passed to the worker thread through a channel with a bounded size (see AsyncBuilder::chan_size). On channel overflow Async will start dropping Records and log a message informing about it after sending more Records is possible again. The exact details of handling overflow is implementation defined, might change and should not be relied on, other than message won’t be dropped as long as channel does not overflow.

Any messages reported by Async will contain slog-async logging Record tag to allow easy custom handling.

Note: On drop Async waits for it’s worker-thread to finish (after handling all previous Records sent to it). If you can’t tolerate the delay, make sure you drop it eg. in another thread.

Implementations§

source§

impl Async

source

pub fn default<D: Drain<Err = Never, Ok = ()> + Send + 'static>( drain: D ) -> Self

New AsyncCore with default parameters

source

pub fn new<D: Drain<Err = Never, Ok = ()> + Send + 'static>( drain: D ) -> AsyncBuilder<D>

Build Async drain with custom parameters

The wrapped drain must handle all results (Drain<Ok=(),Error=Never>) since there’s no way to return it back. See slog::DrainExt::fuse() and slog::DrainExt::ignore_res() for typical error handling strategies.

Trait Implementations§

source§

impl Drain for Async

§

type Ok = ()

Type returned by this drain Read more
§

type Err = AsyncError

Type of potential errors that can be returned by this Drain
source§

fn log( &self, record: &Record<'_>, logger_values: &OwnedKVList ) -> AsyncResult<()>

Handle one logging statement (Record) Read more
source§

fn is_enabled(&self, level: Level) -> bool

Avoid: Check if messages at the specified log level are maybe enabled for this logger. Read more
source§

fn is_critical_enabled(&self) -> bool

Avoid: See is_enabled
source§

fn is_error_enabled(&self) -> bool

Avoid: See is_enabled
source§

fn is_warning_enabled(&self) -> bool

Avoid: See is_enabled
source§

fn is_info_enabled(&self) -> bool

Avoid: See is_enabled
source§

fn is_debug_enabled(&self) -> bool

Avoid: See is_enabled
source§

fn is_trace_enabled(&self) -> bool

Avoid: See is_enabled
source§

fn map<F, R>(self, f: F) -> Rwhere Self: Sized, F: FnOnce(Self) -> R,

Pass Drain through a closure, eg. to wrap into another Drain. Read more
source§

fn filter<F>(self, f: F) -> Filter<Self, F>where Self: Sized, F: FilterFn,

Filter logging records passed to Drain Read more
source§

fn filter_level(self, level: Level) -> LevelFilter<Self>where Self: Sized,

Filter logging records passed to Drain (by level) Read more
source§

fn map_err<F, E>(self, f: F) -> MapError<Self, E>where Self: Sized, F: MapErrFn<Self::Err, E>,

Map logging errors returned by this drain Read more
source§

fn ignore_res(self) -> IgnoreResult<Self>where Self: Sized,

Ignore results returned by this drain Read more
source§

fn fuse(self) -> Fuse<Self>where Self::Err: Debug, Self: Sized,

Make Self panic when returning any errors Read more
source§

impl Drop for Async

source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

§

impl RefUnwindSafe for Async

§

impl Send for Async

§

impl Sync for Async

§

impl Unpin for Async

§

impl UnwindSafe for Async

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> SendRefUnwindSafeDrain for Twhere T: Drain + Send + RefUnwindSafe + ?Sized,

source§

impl<T> SendSyncRefUnwindSafeDrain for Twhere T: Drain + Send + Sync + RefUnwindSafe + ?Sized,

source§

impl<T> SendSyncUnwindSafe for Twhere T: Send + Sync + UnwindSafe + ?Sized,

source§

impl<T> SendSyncUnwindSafeDrain for Twhere T: Drain + Send + Sync + UnwindSafe + ?Sized,