Struct SystemdLayer

Source
pub struct SystemdLayer { /* private fields */ }
Expand description

A configurable tracing-subscriber layer compatible with journald.

The layer used to format and log events. Can be configured to log to stdout, or directly to journald using the sd-journal feature.

let systemd_layer = SystemdLayer::new()
    .with_target(true)
    .use_level_prefix(false)
    .use_color(true);

Implementations§

Source§

impl SystemdLayer

Source

pub fn new() -> Self

Creates a new SystemdLayer with default configuration.

Examples found in repository?
examples/test_log_stdout.rs (line 9)
6fn main() {
7    tracing_subscriber::registry()
8        .with(
9            SystemdLayer::new()
10                .with_target(true)
11                .use_level_prefix(false)
12                .use_color(true)
13                .with_thread_ids(true),
14        )
15        .init();
16
17    root_log_fn(true);
18}
Source

pub fn with_thread_ids(self, log_thread_id: bool) -> Self

Sets whether or not to include thread IDs (default: false)

Examples found in repository?
examples/test_log_stdout.rs (line 13)
6fn main() {
7    tracing_subscriber::registry()
8        .with(
9            SystemdLayer::new()
10                .with_target(true)
11                .use_level_prefix(false)
12                .use_color(true)
13                .with_thread_ids(true),
14        )
15        .init();
16
17    root_log_fn(true);
18}
Source

pub fn separate_spans_with(self, span_separator: &'static str) -> Self

Sets the span separator (default: “::”)

Source

pub fn separate_message_with(self, message_separator: &'static str) -> Self

Sets the message separator (default: “: “)

Source

pub fn with_target(self, display_target: bool) -> Self

Sets whether or not to include the target (default: false)

Examples found in repository?
examples/test_log_stdout.rs (line 10)
6fn main() {
7    tracing_subscriber::registry()
8        .with(
9            SystemdLayer::new()
10                .with_target(true)
11                .use_level_prefix(false)
12                .use_color(true)
13                .with_thread_ids(true),
14        )
15        .init();
16
17    root_log_fn(true);
18}
Source

pub fn function_bracket_left(self, function_bracket_left: &'static str) -> Self

Sets the left bracket for function names (default: “(”)

Source

pub fn function_bracket_right( self, function_bracket_right: &'static str, ) -> Self

Sets the right bracket for function names (default: “)”)

Source

pub fn arguments_equality(self, arguments_equality: &'static str) -> Self

Sets the equality sign for arguments (default: “: “)

Source

pub fn arguments_separator(self, arguments_separator: &'static str) -> Self

Sets the separator for arguments (default: “, “)

Source

pub fn level_separator(self, level_separator: &'static str) -> Self

Sets the separator for levels (default: “ “)

Source

pub fn thread_id_prefix(self, thread_id_prefix: &'static str) -> Self

Sets the prefix for thread IDs (default: “[”)

Source

pub fn thread_id_suffix(self, thread_id_suffix: &'static str) -> Self

Sets the suffix for thread IDs (default: “] “)

Source

pub fn use_level_prefix(self, use_level_prefix: bool) -> Self

Sets whether or not to use level prefixes (default: true)

Examples found in repository?
examples/test_log_stdout.rs (line 11)
6fn main() {
7    tracing_subscriber::registry()
8        .with(
9            SystemdLayer::new()
10                .with_target(true)
11                .use_level_prefix(false)
12                .use_color(true)
13                .with_thread_ids(true),
14        )
15        .init();
16
17    root_log_fn(true);
18}
Source

pub fn use_color(self, use_color: bool) -> Self

Sets whether or not to use color

Examples found in repository?
examples/test_log_stdout.rs (line 12)
6fn main() {
7    tracing_subscriber::registry()
8        .with(
9            SystemdLayer::new()
10                .with_target(true)
11                .use_level_prefix(false)
12                .use_color(true)
13                .with_thread_ids(true),
14        )
15        .init();
16
17    root_log_fn(true);
18}

Trait Implementations§

Source§

impl<S> Layer<S> for SystemdLayer
where S: Subscriber + for<'a> LookupSpan<'a>,

Source§

fn on_event(&self, event: &Event<'_>, ctx: Context<'_, S>)

Notifies this layer that an event has occurred.
Source§

fn on_new_span(&self, attrs: &Attributes<'_>, id: &Id, ctx: Context<'_, S>)

Notifies this layer that a new span was constructed with the given Attributes and Id.
Source§

fn on_register_dispatch(&self, subscriber: &Dispatch)

Performs late initialization when installing this layer as a Subscriber. Read more
Source§

fn on_layer(&mut self, subscriber: &mut S)

Performs late initialization when attaching a Layer to a Subscriber. Read more
Source§

fn register_callsite(&self, metadata: &'static Metadata<'static>) -> Interest

Registers a new callsite with this layer, returning whether or not the layer is interested in being notified about the callsite, similarly to Subscriber::register_callsite. Read more
Source§

fn enabled(&self, metadata: &Metadata<'_>, ctx: Context<'_, S>) -> bool

Returns true if this layer is interested in a span or event with the given metadata in the current Context, similarly to Subscriber::enabled. Read more
Source§

fn on_record(&self, _span: &Id, _values: &Record<'_>, _ctx: Context<'_, S>)

Notifies this layer that a span with the given Id recorded the given values.
Source§

fn on_follows_from(&self, _span: &Id, _follows: &Id, _ctx: Context<'_, S>)

Notifies this layer that a span with the ID span recorded that it follows from the span with the ID follows.
Source§

fn event_enabled(&self, _event: &Event<'_>, _ctx: Context<'_, S>) -> bool

Called before on_event, to determine if on_event should be called. Read more
Source§

fn on_enter(&self, _id: &Id, _ctx: Context<'_, S>)

Notifies this layer that a span with the given ID was entered.
Source§

fn on_exit(&self, _id: &Id, _ctx: Context<'_, S>)

Notifies this layer that the span with the given ID was exited.
Source§

fn on_close(&self, _id: Id, _ctx: Context<'_, S>)

Notifies this layer that the span with the given ID has been closed.
Source§

fn on_id_change(&self, _old: &Id, _new: &Id, _ctx: Context<'_, S>)

Notifies this layer that a span ID has been cloned, and that the subscriber returned a different ID.
Source§

fn and_then<L>(self, layer: L) -> Layered<L, Self, S>
where L: Layer<S>, Self: Sized,

Composes this layer around the given Layer, returning a Layered struct implementing Layer. Read more
Source§

fn with_subscriber(self, inner: S) -> Layered<Self, S>
where Self: Sized,

Composes this Layer with the given Subscriber, returning a Layered struct that implements Subscriber. Read more
Source§

fn with_filter<F>(self, filter: F) -> Filtered<Self, F, S>
where Self: Sized, F: Filter<S>,

Combines self with a Filter, returning a Filtered layer. Read more
Source§

fn boxed(self) -> Box<dyn Layer<S> + Send + Sync>
where Self: Sized + Layer<S> + Send + Sync + 'static, S: Subscriber,

Erases the type of this Layer, returning a Boxed dyn Layer trait object. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where 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> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where 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 T
where U: Into<T>,

Source§

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 T
where U: TryFrom<T>,

Source§

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> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more