Crates.io | logflume |
lib.rs | logflume |
version | 0.0.6 |
source | src |
created_at | 2024-04-08 20:27:38.011719 |
updated_at | 2024-05-10 11:02:59.325695 |
description | A low latency logging library 🪵. |
homepage | |
repository | https://github.com/SBentley/logflume |
max_upload_size | |
id | 1201179 |
size | 42,209 |
use logflume::{info, Level};
use std::fs;
fn main() {
logflume::Logger::new()
.level(Level::Debug)
.cpu(2)
.file("my-log-file.log")
.init()
.expect("Unable to construct logger");
for i in 1..1_000_001 {
info!("number {}", i);
}
logflume::logger().flush();
}
logflume is an asynchronous logger, it hands of all the formatting and writing of logs to another thread to minimize latency on the calling thread. A blocking call to logflume::logger::flush()
is needed if you want to wait for all log messages to be processed, it is advisable to do this before the program shuts down to guarantee that all logs are persisted.