the fast log . This crate uses #! [forbid(unsafe_code)] to ensure everything is implemented in 100% Safe Rust.
A log implementation for extreme speed, using Crossbeam to double the efficiency (as opposed to the standard library MPSC) with a lockless channel, using a channel to write logs asynchronously. Completely use the safe code to achieve, without safe code
Low overhead, based on thread
High performance, use lockless message queue, log is stored in queue, then flush disk. It does not block the caller
Full APPEND mode file writing, high efficiency for solid state/mechanical disk (solid state and mechanical disk sequential write performance is better than random write)
Built-in ZIP compression, compressed file name date + serial number, no need to worry about the log file is too large
Built-in log segmentation, custom log full number of immediately split
Built-in filtering configuration support, can be customized to filter out other library printed logs
Support custom compression algorithms, such as ZIP and LZ4
```
-----------------
log data-> | main channel(crossbeam) | ->
-----------------
---------------- ----------------------
-> |thread channel)| -> background thread | appender1 |
---------------- ----------------------
---------------- ----------------------
-> |thread channel)| -> background thread | appender2 |
---------------- ----------------------
---------------- ----------------------
-> |thread channel)| -> background thread | appender3 |
---------------- ----------------------
---------------- ----------------------
-> |thread channel)| -> background thread | appender4 |
---------------- ----------------------
```
How fast is >?
// Win10 (PC 6 core, mechanical hard disk)
// Win10 (PC 6 core, SSD)
support Future mode,async await based on mpsc channel, tokio or asyncstd support log split,zipcompress
toml
log = "0.4"
fast_log = {version = "1.5"}
or enable zip/lz4/gzip Compression library
```toml
log = "0.4"
fast_log = {version = "1.5" , features = ["lz4","zip","gzip"]} ```
rust
use log::{error, info, warn};
fn main(){
fast_log::init(Config::new().console()).unwrap();
log::info!("Commencing yak shaving{}", 0);
}
rust
use fast_log::{init_log};
use log::{error, info, warn};
fn main(){
fast_log::init(Config::new().file("target/test.log")).unwrap();
log::info!("Commencing yak shaving{}", 0);
info!("Commencing yak shaving");
}
```rust use fastlog::plugin::filesplit::RollingType; use fastlog::consts::LogSize; use fastlog::plugin::packer::LogPacker;
pub fn testfilecompation() { fastlog::init(Config::new() .console() .filesplit("target/logs/", LogSize::MB(1), RollingType::All, LogPacker{})).unwrap(); for _ in 0..200000 { info!("Commencing yak shaving"); } log::logger().flush(); } ```
```rust use fast_log::{LogAppender}; use log::{error, info, warn};
pub struct CustomLog{} impl LogAppender for CustomLog{ fn dolog(&mut self, record: &FastLogRecord) { print!("{}",record); } } fn main(){ let wait = fastlog::init(Config::new().custom(CustomLog {})).unwrap(); info!("Commencing yak shaving"); log::logger().flush(); } ```