Expand description
Utilities for implementing and composing tracing subscribers.
tracing is a framework for instrumenting Rust programs to collect
scoped, structured, and async-aware diagnostics. The Collect trait
represents the functionality necessary to collect this trace data. This
crate contains tools for composing subscribers out of smaller units of
behaviour, and batteries-included implementations of common subscriber
functionality.
tracing-subscriber is intended for use by both Collector authors and
application authors using tracing to instrument their applications.
Compiler support: requires rustc 1.65+
§Subscribers and Filters
The most important component of the tracing-subscriber API is the
Subscribe trait, which provides a composable abstraction for building
collectors. Like the Collect trait, Subscribe defines a
particular behavior for collecting trace data. Unlike Collect,
which implements a complete strategy for how trace data is collected,
Subscribe provide modular implementations of specific behaviors.
Therefore, they can be composed together to form a collector which is
capable of recording traces in a variety of ways. See the subscribe module’s
documentation for details on using subscribers.
In addition, the Filter trait defines an interface for filtering what
spans and events are recorded by a particular subscriber. This allows different
Subscribe implementationss to handle separate subsets of the trace data
emitted by a program. See the documentation on per-subscriber
filtering for more information on using Filters.
§Included Collectors
The following collectors are provided for application authors:
fmt- Formats and logs tracing data (requires thefmtfeature flag)
§Feature Flags
std: Enables APIs that depend on the Rust standard library (enabled by default).alloc: Depend onliballoc(enabled by “std”).env-filter: Enables theEnvFiltertype, which implements filtering similar to theenv_loggercrate. Requires “std”.fmt: Enables thefmtmodule, which provides a subscriber implementation for printing formatted representations of trace events. Enabled by default. Requires “registry” and “std”.ansi: Enablesfmtsupport for ANSI terminal colors. Enabled by default.registry: enables theregistrymodule. Enabled by default. Requires “std”.json: Enablesfmtsupport for JSON output. In JSON output, the ANSI feature does nothing. Requires “fmt” and “std”.local-time: Enables local time formatting when using thetimecrate’s timestamp formatters with thefmtsubscriber.
§Optional Dependencies
tracing-log: Enables better formatting for events emitted bylogmacros in thefmtsubscriber. Enabled by default.time: Enables support for using thetimecrate for timestamp formatting in thefmtsubscriber.smallvec: Causes theEnvFiltertype to use thesmallveccrate (rather thanVec) as a performance optimization. Enabled by default.parking_lot: Use theparking_lotcrate’sRwLockimplementation rather than the Rust standard library’s implementation.
§no_std Support
In embedded systems and other bare-metal applications, tracing can be
used without requiring the Rust standard library, although some features are
disabled. Although most of the APIs provided by tracing-subscriber, such
as fmt and EnvFilter, require the standard library, some
functionality, such as the Subscribe trait, can still be used in
no_std environments.
The dependency on the standard library is controlled by two crate feature
flags, “std”, which enables the dependency on libstd, and “alloc”, which
enables the dependency on liballoc (and is enabled by the “std”
feature). These features are enabled by default, but no_std users can
disable them using:
# Cargo.toml
tracing-subscriber = { version = "0.3", default-features = false }Additional APIs are available when liballoc is available. To enable
liballoc but not std, use:
# Cargo.toml
tracing-subscriber = { version = "0.3", default-features = false, features = ["alloc"] }§Supported Rust Versions
Tracing is built against the latest stable release. The minimum supported version is 1.65. The current Tracing version is not guaranteed to build on Rust versions earlier than the minimum supported version.
Tracing follows the same compiler support policies as the rest of the Tokio project. The current stable Rust compiler and the three most recent minor versions before it will always be supported. For example, if the current stable compiler version is 1.69, the minimum supported version will not be increased past 1.66, three minor versions prior. Increasing the minimum supported compiler version is not considered a semver breaking change as long as doing so complies with this policy.
Re-exports§
pub use fmt::fmt;fmtandstdpub use fmt::Subscriber as FmtSubscriber;fmtandstdpub use filter::EnvFilter;env-filterandstdpub use subscribe::Subscribe;pub use registry::Registry;registryandstd
Modules§
- field
- Utilities for working with fields and field visitors.
- filter
- Subscribers that control which spans and events are enabled by the wrapped collector.
- fmt
fmtandstd - A Collector for formatting and logging
tracingdata. - prelude
- The
tracing-subscriberprelude. - registry
- Storage for span data shared by multiple
Subscribes. - reload
std - Wrapper for a
CollectorSubscribeto allow it to be dynamically reloaded. - subscribe
- The
Subscribetrait, a composable abstraction for building collectors. - util
- Extension traits and other utilities to make working with subscribers more ergonomic.