This crate adds support for external logs, and for statistics tracking through those logs, to the slog
ecosystem.
This crate was written by Metaswitch Networks (@Metaswitch) and made freely available under the Apache License. Contributions are welcome.
External logs are logs that form an external API that end users can rely on, and that do not change without explicit agreement. Using them allows you to treat logs as objects, rather than strings with metadata, allowing compile-time checking of logs.
This repository provides the following.
- An API for easily defining external logs.
- An API for defining statistic values to track, and to modify them based on the external logs
- A
StatisticsLogger
type that wraps anslog::Logger
, which handles logging and updating tracked stats. - An
xlog!
macro for making the logs through theStatisticsLogger
. - An API for retrieving the current values of all stats from the
StatisticsLogger
.
In theory, an external log can be defined simply by making any type implement ExtLoggable
. In practice, external logs will be generated by auto-deriving the ExtLoggable
trait using the slog-extlog-derive
crate from this repository.
Logs can then be generated by using the xlog!
macro to make the logs using a StatisticsLogger
- a wrapper around slog::Logger
which can also track stats.
For more details, see:
- the Rust documentation
- the basic tests for logging examples
- the stats tests for examples with metrics and statistics tracking.