10 releases

0.5.2 Mar 3, 2023
0.5.1 Oct 14, 2022
0.4.1 Jan 23, 2022
0.3.0 Jan 18, 2022
0.1.0 Dec 19, 2021

#167 in Debugging

Download history 27/week @ 2022-12-06 13/week @ 2022-12-13 22/week @ 2022-12-20 8/week @ 2022-12-27 5/week @ 2023-01-03 7/week @ 2023-01-10 4/week @ 2023-01-17 8/week @ 2023-01-24 6/week @ 2023-01-31 11/week @ 2023-02-07 23/week @ 2023-02-14 27/week @ 2023-02-21 41/week @ 2023-02-28 8/week @ 2023-03-07 13/week @ 2023-03-14 9/week @ 2023-03-21

89 downloads per month

MIT/Apache

18KB
400 lines

Flexi-Syslog

crates.io docs.rs

A flexi-logger LogWriter that formats and transports log records to the syslog using the syslog crate.

[dependencies]
flexi_logger = "0.24"
flexi_syslog = "0.5"
syslog = "6.0"

Example Usage

fn main() {
    // syslog's Formatter5424 does not implement the rfc5424 timestamp correctly
    let formatter = flexi_syslog::Formatter5424 {
        facility: syslog::Facility::LOG_USER,
        hostname: None,
        process: "basic".into(),
        pid: 0,
    };

    let sys_logger = syslog::unix(formatter).expect("Failed to init unix socket");

    let syslog_writer = flexi_syslog::log_writer::Builder::default()
        .max_log_level(log::LevelFilter::Info)
        .build(sys_logger);

    let logger = flexi_logger::Logger::try_with_str("info")
        .expect("Failed to init logger")
        .log_to_writer(Box::new(syslog_writer));

    let handle = logger.start().expect("Failed to start logger");

    log::info!("Info gets through");
    log::trace!("Trace is filtered");

    handle.flush();
}

Dependencies

~2–28MB
~474K SLoC