11 releases

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

#273 in Debugging

MIT/Apache

19KB
383 lines

Flexi-Syslog

docs crates build status

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.6–9MB
~68K SLoC