Struct tracing_subscriber::EnvFilter 
source · [−]pub struct EnvFilter { /* private fields */ }Expand description
A Layer which filters spans and events based on a set of filter
directives.
EnvFilter implements both the Layer and Filter traits, so it may
be used for both global filtering and per-layer filtering,
respectively. See the documentation on filtering with Layers
for details.
The Targets type implements a similar form of filtering, but without the
ability to dynamically enable events based on the current span context, and
without filtering on field values. When these features are not required,
Targets provides a lighter-weight alternative to EnvFilter.
Directives
A filter consists of one or more comma-separated directives which match on Spans and Events.
Each directive may have a corresponding maximum verbosity level which
enables (e.g., selects for) spans and events that match. Like log,
tracing considers less exclusive levels (like trace or info) to be more
verbose than more exclusive levels (like error or warn).
The directive syntax is similar to that of env_logger’s. At a high level, the syntax for directives
consists of several parts:
target[span{field=value}]=levelEach component (target, span, field, value, and level) will be covered in turn.
- targetmatches the event or span’s target. In general, this is the module path and/or crate name. Examples of targets- h2,- tokio::net, or- tide::server. For more information on targets, please refer to- Metadata’s documentation.
- spanmatches on the span’s name. If a- spandirective is provided alongside a- target, the- spandirective will match on spans within the- target.
- fieldmatches on fields within spans. Field names can also be supplied without a- valueand will match on any- Spanor- Eventthat has a field with that name. For example:- [span{field=\"value\"}]=debug,- [{field}]=trace.
- valuematches on the value of a span’s field. If a value is a numeric literal or a bool, it will match only on that value. Otherwise, this filter matches the- std::fmt::Debugoutput from the value.
- levelsets a maximum verbosity level accepted by this directive.
When a field value directive ([{<FIELD NAME>=<FIELD_VALUE>}]=...) matches a
value’s std::fmt::Debug output (i.e., the field value in the directive
is not a bool, i64, u64, or f64 literal), the matched pattern may be
interpreted as either a regular expression or as the precise expected
output of the field’s std::fmt::Debug implementation. By default, these
filters are interpreted as regular expressions, but this can be disabled
using the Builder::with_regex builder method to use precise matching
instead.
When field value filters are interpreted as regular expressions, the
[regex-automata crate’s regular expression syntax][re-syntax] is
supported.
Note: When filters are constructed from potentially untrusted inputs, disabling regular expression matching is strongly recommended.
Usage Notes
- The portion of the directive which is included within the square brackets is tracing-specific.
- Any portion of the directive can be omitted.
- The sole exception are the fieldandvaluedirectives. If avalueis provided, afieldmust also be provided. However, the converse does not hold, as fields can be matched without a value.
 
- The sole exception are the 
- If only a level is provided, it will set the maximum level for all Spans andEvents that are not enabled by other filters.
- A directive without a level will enable anything that it matches. This is equivalent to =trace.
- When a crate has a dash in its name, the default target for events will be the crate’s module path as it appears in Rust. This means every dash will be replaced with an underscore.
- A dash in a target will only appear when being specified explicitly:
tracing::info!(target: "target-name", ...);
Example Syntax
- tokio::net=infowill enable all spans or events that:- have the tokio::nettarget,
- at the level infoor above.
 
- have the 
- warn,tokio::net=infowill enable all spans and events that:- are at the level warnor above, or
- have the tokio::nettarget at the levelinfoor above.
 
- are at the level 
- my_crate[span_a]=tracewill enable all spans and events that:- are within the span_aspan or namedspan_aifspan_ahas the targetmy_crate,
- at the level traceor above.
 
- are within the 
- [span_b{name=\"bob\"}]will enable all spans or event that:- have any target,
- are inside a span named span_b,
- which has a field named namewith valuebob,
- at any level.
 
Examples
Parsing an EnvFilter from the default environment
variable (RUST_LOG):
use tracing_subscriber::{EnvFilter, fmt, prelude::*};
tracing_subscriber::registry()
    .with(fmt::layer())
    .with(EnvFilter::from_default_env())
    .init();Parsing an EnvFilter from a user-provided environment
variable:
use tracing_subscriber::{EnvFilter, fmt, prelude::*};
tracing_subscriber::registry()
    .with(fmt::layer())
    .with(EnvFilter::from_env("MYAPP_LOG"))
    .init();Using EnvFilter as a per-layer filter to filter only a single
Layer:
use tracing_subscriber::{EnvFilter, fmt, prelude::*};
// Parse an `EnvFilter` configuration from the `RUST_LOG`
// environment variable.
let filter = EnvFilter::from_default_env();
// Apply the filter to this layer *only*.
let filtered_layer = fmt::layer().with_filter(filter);
// Some other layer, whose output we don't want to filter.
let unfiltered_layer = // ...
tracing_subscriber::registry()
    .with(filtered_layer)
    .with(unfiltered_layer)
    .init();Constructing EnvFilters
An EnvFilter is be constructed by parsing a string containing one or more
directives. The EnvFilter::new constructor parses an EnvFilter from a
string, ignoring any invalid directives, while EnvFilter::try_new
returns an error if invalid directives are encountered. Similarly, the
EnvFilter::from_env and EnvFilter::try_from_env constructors parse
an EnvFilter from the value of the provided environment variable, with
lossy and strict validation, respectively.
A builder interface is available to set additional
configuration options prior to parsing an EnvFilter. See the Builder
type’s documentation for details on the options that can be
configured using the builder.
Implementations
sourceimpl EnvFilter
 
impl EnvFilter
sourcepub const DEFAULT_ENV: &'static str = "RUST_LOG"
 
pub const DEFAULT_ENV: &'static str = "RUST_LOG"
RUST_LOG is the default environment variable used by
EnvFilter::from_default_env and EnvFilter::try_from_default_env.
sourcepub fn builder() -> Builder
 
pub fn builder() -> Builder
Returns a builder that can be used to configure a new EnvFilter
instance.
The Builder type is used to set additional configurations, such as
whether regular expressions are enabled or the
default directive before parsing an
EnvFilter from a string or environment variable.
sourcepub fn from_default_env() -> Self
 
pub fn from_default_env() -> Self
Returns a new EnvFilter from the value of the RUST_LOG environment
variable, ignoring any invalid filter directives.
If the environment variable is empty or not set, or if it contains only
invalid directives, a default directive enabling the ERROR level is
added.
To set additional configuration options prior to parsing the filter, use
the Builder type instead.
This function is equivalent to the following:
use tracing_subscriber::filter::{EnvFilter, LevelFilter};
EnvFilter::builder()
    .with_default_directive(LevelFilter::ERROR.into())
    .from_env_lossy()sourcepub fn from_env<A: AsRef<str>>(env: A) -> Self
 
pub fn from_env<A: AsRef<str>>(env: A) -> Self
Returns a new EnvFilter from the value of the given environment
variable, ignoring any invalid filter directives.
If the environment variable is empty or not set, or if it contains only
invalid directives, a default directive enabling the ERROR level is
added.
To set additional configuration options prior to parsing the filter, use
the Builder type instead.
This function is equivalent to the following:
use tracing_subscriber::filter::{EnvFilter, LevelFilter};
EnvFilter::builder()
    .with_default_directive(LevelFilter::ERROR.into())
    .with_env_var(env)
    .from_env_lossy()sourcepub fn new<S: AsRef<str>>(directives: S) -> Self
 
pub fn new<S: AsRef<str>>(directives: S) -> Self
Returns a new EnvFilter from the directives in the given string,
ignoring any that are invalid.
If the string is empty or contains only invalid directives, a default
directive enabling the ERROR level is added.
To set additional configuration options prior to parsing the filter, use
the Builder type instead.
This function is equivalent to the following:
use tracing_subscriber::filter::{EnvFilter, LevelFilter};
EnvFilter::builder()
    .with_default_directive(LevelFilter::ERROR.into())
    .parse_lossy(directives)sourcepub fn try_new<S: AsRef<str>>(dirs: S) -> Result<Self, ParseError>
 
pub fn try_new<S: AsRef<str>>(dirs: S) -> Result<Self, ParseError>
Returns a new EnvFilter from the directives in the given string,
or an error if any are invalid.
If the string is empty, a default directive enabling the ERROR level
is added.
To set additional configuration options prior to parsing the filter, use
the Builder type instead.
This function is equivalent to the following:
use tracing_subscriber::filter::{EnvFilter, LevelFilter};
EnvFilter::builder()
    .with_default_directive(LevelFilter::ERROR.into())
    .parse(directives)sourcepub fn try_from_default_env() -> Result<Self, FromEnvError>
 
pub fn try_from_default_env() -> Result<Self, FromEnvError>
Returns a new EnvFilter from the value of the RUST_LOG environment
variable, or an error if the environment variable is unset or contains
any invalid filter directives.
To set additional configuration options prior to parsing the filter, use
the Builder type instead.
This function is equivalent to the following:
use tracing_subscriber::EnvFilter;
EnvFilter::builder().try_from_env()sourcepub fn try_from_env<A: AsRef<str>>(env: A) -> Result<Self, FromEnvError>
 
pub fn try_from_env<A: AsRef<str>>(env: A) -> Result<Self, FromEnvError>
Returns a new EnvFilter from the value of the given environment
variable, or an error if the environment variable is unset or contains
any invalid filter directives.
To set additional configuration options prior to parsing the filter, use
the Builder type instead.
This function is equivalent to the following:
use tracing_subscriber::EnvFilter;
EnvFilter::builder().with_env_var(env).try_from_env()sourcepub fn add_directive(self, directive: Directive) -> Self
 
pub fn add_directive(self, directive: Directive) -> Self
Add a filtering directive to this EnvFilter.
The added directive will be used in addition to any previously set directives, either added using this method or provided when the filter is constructed.
Filters may be created from LevelFilter or Level, which will
enable all traces at or below a certain verbosity level, or
parsed from a string specifying a directive.
If a filter directive is inserted that matches exactly the same spans and events as a previous filter, but sets a different level for those spans and events, the previous directive is overwritten.
Examples
From LevelFilter:
use tracing_subscriber::filter::{EnvFilter, LevelFilter};
let mut filter = EnvFilter::from_default_env()
    .add_directive(LevelFilter::INFO.into());Or from Level:
let mut filter = EnvFilter::from_default_env()
    .add_directive(Level::INFO.into());Parsed from a string:
use tracing_subscriber::filter::{EnvFilter, Directive};
let mut filter = EnvFilter::try_from_default_env()?
    .add_directive("my_crate::module=trace".parse()?)
    .add_directive("my_crate::my_other_module::something=info".parse()?);sourcepub fn enabled<S>(&self, metadata: &Metadata<'_>, _: Context<'_, S>) -> bool
 
pub fn enabled<S>(&self, metadata: &Metadata<'_>, _: Context<'_, S>) -> bool
Returns true if this EnvFilter would enable the provided metadata
in the current context.
This is equivalent to calling the Layer::enabled or
Filter::enabled methods on EnvFilter’s implementations of those
traits, but it does not require the trait to be in scope.
sourcepub fn max_level_hint(&self) -> Option<LevelFilter>
 
pub fn max_level_hint(&self) -> Option<LevelFilter>
Returns an optional hint of the highest verbosity level that
this EnvFilter will enable.
This is equivalent to calling the Layer::max_level_hint or
Filter::max_level_hint methods on EnvFilter’s implementations of those
traits, but it does not require the trait to be in scope.
sourcepub fn on_new_span<S>(&self, attrs: &Attributes<'_>, id: &Id, _: Context<'_, S>)
 
pub fn on_new_span<S>(&self, attrs: &Attributes<'_>, id: &Id, _: Context<'_, S>)
Informs the filter that a new span was created.
This is equivalent to calling the Layer::on_new_span or
Filter::on_new_span methods on EnvFilter’s implementations of those
traits, but it does not require the trait to be in scope.
sourcepub fn on_enter<S>(&self, id: &Id, _: Context<'_, S>)
 
pub fn on_enter<S>(&self, id: &Id, _: Context<'_, S>)
Informs the filter that the span with the provided id was entered.
This is equivalent to calling the Layer::on_enter or
Filter::on_enter methods on EnvFilter’s implementations of those
traits, but it does not require the trait to be in scope.
sourcepub fn on_exit<S>(&self, id: &Id, _: Context<'_, S>)
 
pub fn on_exit<S>(&self, id: &Id, _: Context<'_, S>)
Informs the filter that the span with the provided id was exited.
This is equivalent to calling the Layer::on_exit or
Filter::on_exit methods on EnvFilter’s implementations of those
traits, but it does not require the trait to be in scope.
sourcepub fn on_close<S>(&self, id: Id, _: Context<'_, S>)
 
pub fn on_close<S>(&self, id: Id, _: Context<'_, S>)
Informs the filter that the span with the provided id was closed.
This is equivalent to calling the Layer::on_close or
Filter::on_close methods on EnvFilter’s implementations of those
traits, but it does not require the trait to be in scope.
sourcepub fn on_record<S>(&self, id: &Id, values: &Record<'_>, _: Context<'_, S>)
 
pub fn on_record<S>(&self, id: &Id, values: &Record<'_>, _: Context<'_, S>)
Informs the filter that the span with the provided id recorded the
provided field values.
This is equivalent to calling the Layer::on_record or
Filter::on_record methods on EnvFilter’s implementations of those
traits, but it does not require the trait to be in scope
Trait Implementations
sourceimpl<S> Filter<S> for EnvFilter
 
impl<S> Filter<S> for EnvFilter
sourcefn enabled(&self, meta: &Metadata<'_>, ctx: &Context<'_, S>) -> bool
 
fn enabled(&self, meta: &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
sourcefn callsite_enabled(&self, meta: &'static Metadata<'static>) -> Interest
 
fn callsite_enabled(&self, meta: &'static Metadata<'static>) -> Interest
sourcefn max_level_hint(&self) -> Option<LevelFilter>
 
fn max_level_hint(&self) -> Option<LevelFilter>
Returns an optional hint of the highest verbosity level that
this Filter will enable. Read more
sourcefn on_new_span(&self, attrs: &Attributes<'_>, id: &Id, ctx: Context<'_, S>)
 
fn on_new_span(&self, attrs: &Attributes<'_>, id: &Id, ctx: Context<'_, S>)
Notifies this filter that a new span was constructed with the given
Attributes and Id. Read more
sourcefn on_record(&self, id: &Id, values: &Record<'_>, ctx: Context<'_, S>)
 
fn on_record(&self, id: &Id, values: &Record<'_>, ctx: Context<'_, S>)
Notifies this filter that a span with the given Id recorded the given
values. Read more
sourcefn on_enter(&self, id: &Id, ctx: Context<'_, S>)
 
fn on_enter(&self, id: &Id, ctx: Context<'_, S>)
Notifies this filter that a span with the given ID was entered. Read more
sourceimpl<S: Subscriber> Layer<S> for EnvFilter
 
impl<S: Subscriber> Layer<S> for EnvFilter
sourcefn register_callsite(&self, metadata: &'static Metadata<'static>) -> Interest
 
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
sourcefn enabled(&self, metadata: &Metadata<'_>, ctx: Context<'_, S>) -> bool
 
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
sourcefn on_new_span(&self, attrs: &Attributes<'_>, id: &Id, ctx: Context<'_, S>)
 
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. Read more
sourcefn on_record(&self, id: &Id, values: &Record<'_>, ctx: Context<'_, S>)
 
fn on_record(&self, id: &Id, values: &Record<'_>, ctx: Context<'_, S>)
Notifies this layer that a span with the given Id recorded the given
values. Read more
sourcefn on_enter(&self, id: &Id, ctx: Context<'_, S>)
 
fn on_enter(&self, id: &Id, ctx: Context<'_, S>)
Notifies this layer that a span with the given ID was entered.
sourcefn on_exit(&self, id: &Id, ctx: Context<'_, S>)
 
fn on_exit(&self, id: &Id, ctx: Context<'_, S>)
Notifies this layer that the span with the given ID was exited.
sourcefn on_close(&self, id: Id, ctx: Context<'_, S>)
 
fn on_close(&self, id: Id, ctx: Context<'_, S>)
Notifies this layer that the span with the given ID has been closed.
sourcefn on_layer(&mut self, subscriber: &mut S)
 
fn on_layer(&mut self, subscriber: &mut S)
Performs late initialization when attaching a Layer to a
Subscriber. Read more
sourcefn on_follows_from(&self, _span: &Id, _follows: &Id, _ctx: Context<'_, S>)
 
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. Read more
sourcefn on_event(&self, _event: &Event<'_>, _ctx: Context<'_, S>)
 
fn on_event(&self, _event: &Event<'_>, _ctx: Context<'_, S>)
Notifies this layer that an event has occurred.
sourcefn on_id_change(&self, _old: &Id, _new: &Id, _ctx: Context<'_, S>)
 
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. Read more
sourcefn and_then<L>(self, layer: L) -> Layered<L, Self, S> where
    L: Layer<S>,
    Self: Sized, 
 
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
sourcefn with_subscriber(self, inner: S) -> Layered<Self, S> where
    Self: Sized, 
 
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
sourcefn with_filter<F>(self, filter: F) -> Filtered<Self, F, S> where
    Self: Sized,
    F: Filter<S>, 
 
fn with_filter<F>(self, filter: F) -> Filtered<Self, F, S> where
    Self: Sized,
    F: Filter<S>, 
Auto Trait Implementations
impl RefUnwindSafe for EnvFilter
impl Send for EnvFilter
impl Sync for EnvFilter
impl Unpin for EnvFilter
impl UnwindSafe for EnvFilter
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
    T: ?Sized, 
 
impl<T> BorrowMut<T> for T where
    T: ?Sized, 
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> Instrument for T
 
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
sourcefn in_current_span(self) -> Instrumented<Self>
 
fn in_current_span(self) -> Instrumented<Self>
sourceimpl<T> WithSubscriber for T
 
impl<T> WithSubscriber for T
sourcefn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
    S: Into<Dispatch>, 
 
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
sourcefn with_current_subscriber(self) -> WithDispatch<Self>
 
fn with_current_subscriber(self) -> WithDispatch<Self>
Attaches the current default Subscriber to this type, returning a
WithDispatch wrapper. Read more
