16 releases

0.7.5 Jun 8, 2023
0.7.3 Mar 14, 2023
0.7.1 Oct 14, 2022
0.7.0-rc.0 Jul 27, 2022
0.1.1 Jul 27, 2019

#39 in Filesystem

Download history 7636/week @ 2023-12-11 6985/week @ 2023-12-18 4052/week @ 2023-12-25 6572/week @ 2024-01-01 6809/week @ 2024-01-08 7248/week @ 2024-01-15 9731/week @ 2024-01-22 11427/week @ 2024-01-29 10842/week @ 2024-02-05 13033/week @ 2024-02-12 16580/week @ 2024-02-19 11947/week @ 2024-02-26 17169/week @ 2024-03-04 15153/week @ 2024-03-11 15967/week @ 2024-03-18 13976/week @ 2024-03-25

62,778 downloads per month
Used in 15 crates (10 directly)

MIT license

67KB
1K SLoC

file-rotate

Rotate files with configurable suffix.

Look to the docs for explanatory examples of all features, like:

  • Using count or timestamp as suffix
  • Age-based deletion of log files
  • Optional compression
  • Getting a list of log files

Limitations / known issues:

  • file-rotate assumes that no other process or user moves files around in the logging directory, but we want to find a way to support this

Following are some supplementary examples to get started.

Basic example

use file_rotate::{FileRotate, ContentLimit, compression::Compression, suffix::AppendCount};
use std::{fs, io::Write, path::PathBuf};

fn main() {
    let mut log = FileRotate::new("logs/log", AppendCount::new(2), ContentLimit::Lines(3), Compression::None, None);

    // Write a bunch of lines
    writeln!(log, "Line 1: Hello World!");
    for idx in 2..=10 {
        writeln!(log, "Line {}", idx);
    }
}
$ ls logs
log  log.1  log.2

$ cat log.2 log.1 log
Line 4
Line 5
Line 6
Line 7
Line 8
Line 9
Line 10

Example with timestamp suffixes

let mut log = FileRotate::new(
    "logs/log",
    AppendTimestamp::default(FileLimit::MaxFiles(3)),
    ContentLimit::Lines(3),
    Compression::None,
    None,
);

// Write a bunch of lines
writeln!(log, "Line 1: Hello World!");
for idx in 2..=10 {
    std::thread::sleep(std::time::Duration::from_millis(200));
    writeln!(log, "Line {}", idx);
}
$ ls logs
log                  log.20210825T151133.1
log.20210825T151133  log.20210825T151134

$ cat logs/*
Line 10
Line 1: Hello World!
Line 2
Line 3
Line 4
Line 5
Line 6
Line 7
Line 8
Line 9

The timestamp format (including the extra trailing .N) works by default so that the lexical ordering of filenames equals the chronological ordering. So it almost works perfectly with cat logs/*, except that log is smaller (lexically "older") than all the rest. This can of course be fixed with a more complex script to assemble the logs.

License

This project is licensed under the MIT license.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in file-rotate by you, shall be licensed as MIT, without any additional terms or conditions.

Dependencies

~1.3–7.5MB
~32K SLoC