nixpkgs/nixos/modules/services/monitoring/collectd.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

157 lines
4.0 KiB
Nix
Raw Normal View History

2014-09-13 00:03:15 +00:00
{ config, pkgs, lib, ... }:
let
cfg = config.services.collectd;
baseDirLine = ''BaseDir "${cfg.dataDir}"'';
unvalidated_conf = pkgs.writeText "collectd-unvalidated.conf" cfg.extraConfig;
2014-09-13 00:03:15 +00:00
conf = if cfg.validateConfig then
pkgs.runCommand "collectd.conf" {} ''
echo testing ${unvalidated_conf}
cp ${unvalidated_conf} collectd.conf
# collectd -t fails if BaseDir does not exist.
substituteInPlace collectd.conf --replace ${lib.escapeShellArgs [ baseDirLine ]} 'BaseDir "."'
${package}/bin/collectd -t -C collectd.conf
cp ${unvalidated_conf} $out
'' else unvalidated_conf;
package =
if cfg.buildMinimalPackage
then minimalPackage
else cfg.package;
minimalPackage = cfg.package.override {
enabledPlugins = [ "syslog" ] ++ builtins.attrNames cfg.plugins;
};
2014-09-13 00:03:15 +00:00
in {
options.services.collectd = with lib.types; {
enable = lib.mkEnableOption "collectd agent";
2014-09-13 00:03:15 +00:00
validateConfig = lib.mkOption {
default = true;
description = ''
Validate the syntax of collectd configuration file at build time.
Disable this if you use the Include directive on files unavailable in
the build sandbox, or when cross-compiling.
'';
type = types.bool;
};
package = lib.mkPackageOption pkgs "collectd" { };
buildMinimalPackage = lib.mkOption {
default = false;
description = ''
Build a minimal collectd package with only the configured `services.collectd.plugins`
'';
type = bool;
2016-02-15 02:34:49 +00:00
};
user = lib.mkOption {
2014-09-13 00:03:15 +00:00
default = "collectd";
description = ''
User under which to run collectd.
'';
type = nullOr str;
};
dataDir = lib.mkOption {
2014-09-13 00:03:15 +00:00
default = "/var/lib/collectd";
description = ''
Data directory for collectd agent.
'';
type = path;
};
autoLoadPlugin = lib.mkOption {
2014-09-13 00:03:15 +00:00
default = false;
description = ''
Enable plugin autoloading.
'';
type = bool;
};
include = lib.mkOption {
2014-09-13 00:03:15 +00:00
default = [];
description = ''
Additional paths to load config from.
'';
type = listOf str;
};
plugins = lib.mkOption {
2019-10-17 19:40:57 +00:00
default = {};
example = { cpu = ""; memory = ""; network = "Server 192.168.1.1 25826"; };
description = ''
Attribute set of plugin names to plugin config segments
'';
type = attrsOf lines;
2019-10-17 19:40:57 +00:00
};
extraConfig = lib.mkOption {
2014-09-13 00:03:15 +00:00
default = "";
description = ''
Extra configuration for collectd. Use mkBefore to add lines before the
default config, and mkAfter to add them below.
2014-09-13 00:03:15 +00:00
'';
type = lines;
};
};
config = lib.mkIf cfg.enable {
# 1200 is after the default (1000) but before mkAfter (1500).
services.collectd.extraConfig = lib.mkOrder 1200 ''
${baseDirLine}
AutoLoadPlugin ${lib.boolToString cfg.autoLoadPlugin}
Hostname "${config.networking.hostName}"
LoadPlugin syslog
<Plugin "syslog">
LogLevel "info"
NotifyLevel "OKAY"
</Plugin>
${lib.concatStrings (lib.mapAttrsToList (plugin: pluginConfig: ''
LoadPlugin ${plugin}
<Plugin "${plugin}">
${pluginConfig}
</Plugin>
'') cfg.plugins)}
${lib.concatMapStrings (f: ''
Include "${f}"
'') cfg.include}
'';
systemd.tmpfiles.rules = [
"d '${cfg.dataDir}' - ${cfg.user} - - -"
];
2014-09-13 00:03:15 +00:00
systemd.services.collectd = {
description = "Collectd Monitoring Agent";
after = [ "network.target" ];
wantedBy = [ "multi-user.target" ];
serviceConfig = {
ExecStart = "${package}/sbin/collectd -C ${conf} -f";
User = cfg.user;
Restart = "on-failure";
RestartSec = 3;
2014-09-13 00:03:15 +00:00
};
};
2014-09-13 00:03:15 +00:00
users.users = lib.optionalAttrs (cfg.user == "collectd") {
collectd = {
isSystemUser = true;
group = "collectd";
};
2014-09-13 00:03:15 +00:00
};
users.groups = lib.optionalAttrs (cfg.user == "collectd") {
collectd = {};
};
2014-09-13 00:03:15 +00:00
};
}