Crate tracing_subscriber[−][src]
Utilities for implementing and composing tracing subscribers.
tracing is a framework for instrumenting Rust programs to collect
scoped, structured, and async-aware diagnostics. The Subscriber 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 Subscriber authors and
application authors using tracing to instrument their applications.
Compiler support: requires rustc 1.42+
Included Subscribers
The following Subscribers are provided for application authors:
fmt- Formats and logs tracing data (requires thefmtfeature flag)
Feature Flags
env-filter: Enables theEnvFiltertype, which implements filtering similar to theenv_loggercrate. Enabled by default.fmt: Enables thefmtmodule, which provides a subscriber implementation for printing formatted representations of trace events. Enabled by default.ansi: Enablesfmtsupport for ANSI terminal colors. Enabled by default.registry: enables theregistrymodule. Enabled by default.json: Enablesfmtsupport for JSON output. In JSON output, the ANSI feature does nothing.
Optional Dependencies
tracing-log: Enables better formatting for events emitted bylogmacros in thefmtsubscriber. On by default.chrono: Enables human-readable time formatting in thefmtsubscriber. Enabled by default.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.
Supported Rust Versions
Tracing is built against the latest stable release. The minimum supported version is 1.42. 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.45, the minimum supported version will not be increased past 1.42, 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 layer::Layer; | |
pub use fmt::Subscriber as FmtSubscriber; | |
pub use fmt::fmt; |
Modules
| field | Utilities for working with fields and field visitors. |
| filter |
|
| fmt | A |
| layer | A composable abstraction for building |
| prelude | The |
| registry | Storage for span data shared by multiple |
| reload | Wrapper for a |
| util | Extension traits and other utilities to make working with subscribers more ergonomic. |
Structs
| CurrentSpan | Tracks the currently executing span on a per-thread basis. |
| EnvFilter | A |
| Registry | A shared, reusable store for spans. |
Functions
| registry |