2012-07-11 19:22:16 +04:00
|
|
|
{ config, pkgs, ... }:
|
|
|
|
|
|
|
|
with pkgs.lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.services.logstash;
|
|
|
|
|
|
|
|
in
|
|
|
|
|
|
|
|
{
|
|
|
|
###### interface
|
|
|
|
|
|
|
|
options = {
|
|
|
|
services.logstash = {
|
|
|
|
enable = mkOption {
|
|
|
|
default = false;
|
2013-10-12 14:28:48 +04:00
|
|
|
description = "Enable logstash";
|
2012-07-11 19:22:16 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
inputConfig = mkOption {
|
2013-10-12 14:28:48 +04:00
|
|
|
default = ''stdin { type => "example" }'';
|
|
|
|
description = "Logstash input configuration";
|
2013-10-31 18:59:59 +04:00
|
|
|
example = ''
|
|
|
|
# Read from journal
|
|
|
|
pipe {
|
|
|
|
command => "${pkgs.systemd}/bin/journalctl -f -o json"
|
|
|
|
type => "syslog" codec => json {}
|
|
|
|
}
|
|
|
|
'';
|
2012-07-11 19:22:16 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
filterConfig = mkOption {
|
2013-10-12 14:28:48 +04:00
|
|
|
default = ''noop {}'';
|
|
|
|
description = "logstash filter configuration";
|
2013-10-31 18:59:59 +04:00
|
|
|
example = ''
|
|
|
|
if [type] == "syslog" {
|
|
|
|
# Keep only relevant systemd fields
|
|
|
|
# http://www.freedesktop.org/software/systemd/man/systemd.journal-fields.html
|
|
|
|
prune {
|
|
|
|
whitelist_names => [
|
|
|
|
"type", "@timestamp", "@version",
|
|
|
|
"MESSAGE", "PRIORITY", "SYSLOG_FACILITY",
|
|
|
|
]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
'';
|
2012-07-11 19:22:16 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
outputConfig = mkOption {
|
2013-10-12 14:28:48 +04:00
|
|
|
default = ''stdout { debug => true debug_format => "json"}'';
|
|
|
|
description = "Logstash output configuration";
|
2013-10-31 18:59:59 +04:00
|
|
|
example = ''
|
|
|
|
redis { host => "localhost" data_type => "list" key => "logstash" codec => json }
|
|
|
|
elasticsearch { embedded => true }
|
|
|
|
'';
|
2012-07-11 19:22:16 +04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
###### implementation
|
|
|
|
|
2013-10-12 14:28:48 +04:00
|
|
|
config = mkIf cfg.enable {
|
2013-01-16 15:33:18 +04:00
|
|
|
systemd.services.logstash = with pkgs; {
|
2012-07-11 19:22:16 +04:00
|
|
|
description = "Logstash daemon";
|
2012-10-30 17:18:51 +04:00
|
|
|
wantedBy = [ "multi-user.target" ];
|
2012-07-11 19:22:16 +04:00
|
|
|
|
2013-10-12 14:28:48 +04:00
|
|
|
serviceConfig = {
|
|
|
|
ExecStart = "${jre}/bin/java -jar ${logstash} agent -f ${writeText "logstash.conf" ''
|
|
|
|
input {
|
|
|
|
${cfg.inputConfig}
|
|
|
|
}
|
2012-07-11 19:22:16 +04:00
|
|
|
|
2013-10-12 14:28:48 +04:00
|
|
|
filter {
|
|
|
|
${cfg.filterConfig}
|
|
|
|
}
|
2012-07-11 19:22:16 +04:00
|
|
|
|
2013-10-12 14:28:48 +04:00
|
|
|
output {
|
|
|
|
${cfg.outputConfig}
|
|
|
|
}
|
|
|
|
''}";
|
|
|
|
};
|
2012-07-11 19:22:16 +04:00
|
|
|
};
|
2013-10-12 14:28:48 +04:00
|
|
|
};
|
2012-07-11 19:22:16 +04:00
|
|
|
}
|