3 releases

0.1.2 Apr 25, 2021
0.1.1 Apr 2, 2021
0.1.0 Oct 3, 2020

#238 in Debugging

Download history 34/week @ 2022-06-02 3/week @ 2022-06-09 4/week @ 2022-06-16 7/week @ 2022-06-23 74/week @ 2022-06-30 95/week @ 2022-07-07 139/week @ 2022-07-14 119/week @ 2022-07-21 33/week @ 2022-07-28 42/week @ 2022-08-04 85/week @ 2022-08-11 94/week @ 2022-08-18 45/week @ 2022-08-25 16/week @ 2022-09-01 33/week @ 2022-09-08 63/week @ 2022-09-15

187 downloads per month
Used in unftp

Apache-2.0

15KB
278 lines

slog-redis

This crate implements a slog drain that outputs to a Redis list.

Useful for centralized logging using a RELK stack (Redis, Elasticsearch, Logstash and Kibana). All log messages are sent to a Redis server, in Logstash message V0 format, ready to be parsed/processed by Logstash.

The format looks like this:

 {
    "@timestamp": ${timeRFC3339},
    "@source_host": ${hostname},
    "@message": ${message},
    "@fields": {
       "level": ${levelLowercase},
       "application": ${appName}
       ... // logged field 1
       ... // logged field 2
       ...
   }

Example Usage:

 use slog::*;
 use slog_redis::Builder;

 let redis_drain = Builder::new("my-app-name")
   .redis_host("localhost")
   .redis_key("my_redis_list_key")
   .build()
   .unwrap();

 let drain = slog_async::Async::new(redis_drain.fuse()).build().fuse();

 let log = Logger::root(drain, o!());
 info!(log, "Send me to {}!", "Redis"; "msg" => "Hello World!");

Dependencies

~5–11MB
~223K SLoC