blob: 16a729d1f313df26a35d6d9510d4ddb36dc456ff (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
|
{ me, config, lib, ... }:
let
inherit (lib) mkOption mkEnableOption types;
cfg = config.foundation.monitoring;
victoriaDefaultPort = 8428;
nodeExporterPort = 9001;
cadvisorExporterPort = 9002;
nginxExporterPort = 9113;
dockerExporterPort = 9323;
in
{
imports = [ ../../services/monitoring/wrapper.nix ];
options.foundation.monitoring = {
server = {
enable = mkEnableOption "monitoring server";
hosts = mkOption {
type = with types; listOf (submodule {
options = {
name = mkOption { type = str; };
ip = mkOption { type = str; };
};
});
default = [ ];
};
};
client = {
enable = mkEnableOption "monitoring client";
};
};
config = lib.mkMerge [
(lib.mkIf cfg.server.enable {
foundation.internal.monitoringService = true;
services.vmagent = {
enable = true;
remoteWrite.url = "http://${me.tailscale.ip}:${toString victoriaDefaultPort}/api/v1/write";
prometheusConfig = {
global = {
scrape_interval = "15s";
};
scrape_configs = let
exporter = job: port: {
job_name = job;
static_configs = map ({ name, ip }: {
targets = [ "${ip}:${toString port}" ];
labels = { instance = name; };
}) cfg.server.hosts;
};
in [
(exporter "node" nodeExporterPort)
(exporter "docker" dockerExporterPort)
(exporter "cadvisor" cadvisorExporterPort)
(exporter "nginx" nginxExporterPort)
];
};
};
})
(lib.mkIf (cfg.client.enable || cfg.server.enable) {
services = {
prometheus.exporters = {
node = {
enable = true;
openFirewall = false;
listenAddress = me.tailscale.ip;
port = nodeExporterPort;
};
nginx = {
enable = true;
openFirewall = false;
listenAddress = me.tailscale.ip;
port = nginxExporterPort;
};
};
cadvisor = {
enable = true;
port = cadvisorExporterPort;
listenAddress = me.tailscale.ip;
};
};
})
];
}
|