Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fast/logforth
A versatile and extensible logging implementation.
https://github.com/fast/logforth
logging rust
Last synced: 2 days ago
JSON representation
A versatile and extensible logging implementation.
- Host: GitHub
- URL: https://github.com/fast/logforth
- Owner: fast
- License: apache-2.0
- Created: 2024-08-01T03:38:22.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2025-01-10T16:04:55.000Z (12 days ago)
- Last Synced: 2025-01-13T04:05:30.570Z (9 days ago)
- Topics: logging, rust
- Language: Rust
- Homepage: https://docs.rs/logforth/
- Size: 288 KB
- Stars: 47
- Watchers: 1
- Forks: 8
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# Logforth
[![Crates.io][crates-badge]][crates-url]
[![Documentation][docs-badge]][docs-url]
[![MSRV 1.80][msrv-badge]](https://www.whatrustisit.com)
[![Apache 2.0 licensed][license-badge]][license-url]
[![Build Status][actions-badge]][actions-url][crates-badge]: https://img.shields.io/crates/v/logforth.svg
[crates-url]: https://crates.io/crates/logforth
[docs-badge]: https://docs.rs/logforth/badge.svg
[msrv-badge]: https://img.shields.io/badge/MSRV-1.80-green?logo=rust
[docs-url]: https://docs.rs/logforth
[license-badge]: https://img.shields.io/crates/l/logforth
[license-url]: LICENSE
[actions-badge]: https://github.com/fast/logforth/workflows/CI/badge.svg
[actions-url]:https://github.com/fast/logforth/actions?query=workflow%3ACILogforth is a flexible and easy-to-use logging framework for Rust applications. It allows you to configure multiple dispatches, filters, and appenders to customize your logging setup according to your needs.
## Features
- **Multiple Dispatches**: Configure different logging behaviors for different parts of your application.
- **Flexible Filters**: Use built-in or custom filters to control which log records are processed.
- **Various Appenders**: Output logs to stdout, stderr, files, or even send them to OpenTelemetry collectors.
- **Custom Layouts**: Format log records using predefined layouts or create your own.## Getting Started
Add `log` and `logforth` to your `Cargo.toml`:
```shell
cargo add log
cargo add logforth
```## Simple Usage
Set up a basic logger that outputs to stdout:
```rust
fn main() {
logforth::stdout().apply();log::info!("This is an info message.");
log::debug!("This debug message will not be printed by default.");
}
```## Advanced Usage
Configure multiple dispatches with different filters and appenders:
```rust
use logforth::append;
use log::LevelFilter;fn main() {
logforth::builder()
.dispatch(|d| d
.filter(LevelFilter::Error)
.append(append::Stderr::default()))
.dispatch(|d| d
.filter(LevelFilter::Info)
.append(append::Stdout::default()))
.apply();log::error!("This error will be logged to stderr.");
log::info!("This info will be logged to stdout.");
log::debug!("This debug message will not be logged.");
}
```Read more demos under the [examples](examples) directory.
## Documentation
Read the online documents at https://docs.rs/logforth.
## Minimum Rust version policy
This crate is built against the latest stable release, and its minimum supported rustc version is 1.80.0.
The policy is that the minimum Rust version required to use this crate can be increased in minor version updates. For example, if Logforth 1.0 requires Rust 1.20.0, then Logforth 1.0.z for all values of z will also require Rust 1.20.0 or newer. However, Logforth 1.y for y > 0 may require a newer minimum version of Rust.
## When to release a 1.0 version
After one year of practicing the interfaces, if there are no further blockers, I'll release a 1.0 version. So consequently, it can be as early as 2025-08.
### Stabilize targets
To release a 1.0 version, it's essential to declare what targets this crate wants to stabilize. Even beyond 1.0, it's helpful to distinguish different portions of this crate to allow unstable modules to make breaking changes to improve their quality, just as how rust-lang's stabilization mechanism works.
Basically, this crate contains:
* Fundamental logging APIs (Appender, Layout, Filter, Dispatch, Logger, etc.): these MUST BE stabilized before 1.0.
* Basic layouts and filters (all current existing): these SHOULD BE stabilized before 1.0.
* Basic appenders (Stdout, Stderr, RollingFile): these SHOULD BE stabilized before 1.0.
* Advanced appenders (Fastrace, OpentelemetryLog, Syslog, etc.): to-be-determined how to stabilize them.Generally, there are known usage for Fastrace and OpentelemetryLog, so we can confidently announce their stable version; others are still waiting for feedback.
## License and Origin
This project is licensed under [Apache License, Version 2.0](LICENSE).
The name `Logforth` comes from an antonym to the [`Logback`](https://logback.qos.ch/) project.