mirror of
https://github.com/gensokyo-zone/infrastructure.git
synced 2026-02-09 04:19:19 -08:00
chore(monitoring): nf-fmt-nix
This commit is contained in:
parent
6fb140c7e6
commit
a0a7df1b0e
6 changed files with 164 additions and 141 deletions
|
|
@ -11,18 +11,24 @@
|
|||
nodeExporterSystems =
|
||||
filter (
|
||||
system:
|
||||
system.config.access.online.enable &&
|
||||
system.config.exports.prometheus.exporter.services != [ ]
|
||||
system.config.access.online.enable
|
||||
&& system.config.exports.prometheus.exporter.services != []
|
||||
)
|
||||
(attrValues systems);
|
||||
mkPortTarget = { system, service, portName }: let
|
||||
mkPortTarget = {
|
||||
system,
|
||||
service,
|
||||
portName,
|
||||
}: let
|
||||
port = service.ports.${portName};
|
||||
in "${access.getAddressFor system.config.name "lan"}:${toString port.port}";
|
||||
mkServiceConfig = system: serviceName: let
|
||||
service = system.config.exports.services.${serviceName};
|
||||
targets = map (portName: mkPortTarget {
|
||||
inherit system service portName;
|
||||
}) service.prometheus.exporter.ports;
|
||||
targets = map (portName:
|
||||
mkPortTarget {
|
||||
inherit system service portName;
|
||||
})
|
||||
service.prometheus.exporter.ports;
|
||||
in {
|
||||
job_name = "${system.config.name}-${service.id}";
|
||||
static_configs = [
|
||||
|
|
|
|||
|
|
@ -7,8 +7,9 @@
|
|||
inherit (lib.attrsets) attrValues;
|
||||
inherit (lib.lists) concatMap toList;
|
||||
allExporters = let
|
||||
exporters = removeAttrs config.services.prometheus.exporters [ "unifi-poller" ];
|
||||
in concatMap toList (attrValues exporters);
|
||||
exporters = removeAttrs config.services.prometheus.exporters ["unifi-poller"];
|
||||
in
|
||||
concatMap toList (attrValues exporters);
|
||||
in {
|
||||
config = {
|
||||
services.prometheus.exporters = {
|
||||
|
|
@ -57,8 +58,11 @@ in {
|
|||
}
|
||||
];
|
||||
};
|
||||
networking.firewall.interfaces.lan.allowedTCPPorts = map (exporter:
|
||||
mkIf (exporter.enable && !exporter.openFirewall) 999
|
||||
) allExporters;
|
||||
networking.firewall.interfaces.lan.allowedTCPPorts =
|
||||
map (
|
||||
exporter:
|
||||
mkIf (exporter.enable && !exporter.openFirewall) exporter.port
|
||||
)
|
||||
allExporters;
|
||||
};
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,8 +1,5 @@
|
|||
let
|
||||
portModule = {
|
||||
lib,
|
||||
...
|
||||
}: let
|
||||
portModule = {lib, ...}: let
|
||||
inherit (lib.options) mkEnableOption;
|
||||
in {
|
||||
options.prometheus = with lib.types; {
|
||||
|
|
@ -27,7 +24,7 @@ let
|
|||
};
|
||||
labels = mkOption {
|
||||
type = attrsOf str;
|
||||
default = { };
|
||||
default = {};
|
||||
};
|
||||
};
|
||||
};
|
||||
|
|
@ -41,120 +38,134 @@ let
|
|||
exporter.ports = mkOptionDefault (attrNames exporterPorts);
|
||||
};
|
||||
};
|
||||
in {
|
||||
config,
|
||||
gensokyo-zone,
|
||||
lib,
|
||||
...
|
||||
}: let
|
||||
inherit (gensokyo-zone.lib) mapListToAttrs mapAlmostOptionDefaults mkAlmostOptionDefault;
|
||||
inherit (lib.options) mkOption;
|
||||
inherit (lib.modules) mkIf mkOptionDefault;
|
||||
inherit (lib.attrsets) attrNames filterAttrs nameValuePair;
|
||||
mkExporter = { name, port }: nameValuePair "prometheus-exporters-${name}" ({config, ...}: {
|
||||
nixos = {
|
||||
serviceAttrPath = ["services" "prometheus" "exporters" name];
|
||||
assertions = mkIf config.enable [
|
||||
(nixosConfig: {
|
||||
assertion = config.ports.default.port == nixosConfig.services.prometheus.exporters.${name}.port;
|
||||
message = "port mismatch";
|
||||
})
|
||||
];
|
||||
};
|
||||
ports.default = mapAlmostOptionDefaults {
|
||||
inherit port;
|
||||
protocol = "http";
|
||||
} // {
|
||||
prometheus.exporter.enable = true;
|
||||
};
|
||||
});
|
||||
exporters = mapListToAttrs mkExporter [
|
||||
{ name = "node"; port = 9091; }
|
||||
];
|
||||
in {
|
||||
options.exports = with lib.types; {
|
||||
prometheus = {
|
||||
exporter.services = mkOption {
|
||||
type = listOf str;
|
||||
};
|
||||
};
|
||||
services = mkOption {
|
||||
type = attrsOf (submoduleWith {
|
||||
modules = [serviceModule];
|
||||
in
|
||||
{
|
||||
config,
|
||||
gensokyo-zone,
|
||||
lib,
|
||||
...
|
||||
}: let
|
||||
inherit (gensokyo-zone.lib) mapListToAttrs mapAlmostOptionDefaults mkAlmostOptionDefault;
|
||||
inherit (lib.options) mkOption;
|
||||
inherit (lib.modules) mkIf mkOptionDefault;
|
||||
inherit (lib.attrsets) attrNames filterAttrs nameValuePair;
|
||||
mkExporter = {
|
||||
name,
|
||||
port,
|
||||
}:
|
||||
nameValuePair "prometheus-exporters-${name}" ({config, ...}: {
|
||||
nixos = {
|
||||
serviceAttrPath = ["services" "prometheus" "exporters" name];
|
||||
assertions = mkIf config.enable [
|
||||
(nixosConfig: {
|
||||
assertion = config.ports.default.port == nixosConfig.services.prometheus.exporters.${name}.port;
|
||||
message = "port mismatch";
|
||||
})
|
||||
];
|
||||
};
|
||||
ports.default =
|
||||
mapAlmostOptionDefaults {
|
||||
inherit port;
|
||||
protocol = "http";
|
||||
}
|
||||
// {
|
||||
prometheus.exporter.enable = true;
|
||||
};
|
||||
});
|
||||
};
|
||||
};
|
||||
config.exports.prometheus = let
|
||||
exporterServices = filterAttrs (_: service: service.enable && service.prometheus.exporter.ports != [ ]) config.exports.services;
|
||||
exporters = mapListToAttrs mkExporter [
|
||||
{
|
||||
name = "node";
|
||||
port = 9091;
|
||||
}
|
||||
];
|
||||
in {
|
||||
exporter.services = mkOptionDefault (attrNames exporterServices);
|
||||
};
|
||||
config.exports.services = {
|
||||
prometheus = {config, ...}: {
|
||||
id = mkAlmostOptionDefault "prometheus";
|
||||
nixos = {
|
||||
serviceAttr = "prometheus";
|
||||
assertions = mkIf config.enable [
|
||||
(nixosConfig: {
|
||||
assertion = config.ports.default.port == nixosConfig.services.prometheus.port;
|
||||
message = "port mismatch";
|
||||
})
|
||||
];
|
||||
options.exports = with lib.types; {
|
||||
prometheus = {
|
||||
exporter.services = mkOption {
|
||||
type = listOf str;
|
||||
};
|
||||
};
|
||||
ports.default = mapAlmostOptionDefaults {
|
||||
port = 9090;
|
||||
protocol = "http";
|
||||
services = mkOption {
|
||||
type = attrsOf (submoduleWith {
|
||||
modules = [serviceModule];
|
||||
});
|
||||
};
|
||||
};
|
||||
grafana = {config, ...}: {
|
||||
id = mkAlmostOptionDefault "grafana";
|
||||
nixos = {
|
||||
serviceAttr = "grafana";
|
||||
assertions = mkIf config.enable [
|
||||
(nixosConfig: {
|
||||
assertion = config.ports.default.port == nixosConfig.services.grafana.settings.server.http_port;
|
||||
message = "port mismatch";
|
||||
})
|
||||
];
|
||||
};
|
||||
ports.default = mapAlmostOptionDefaults {
|
||||
port = 9092;
|
||||
protocol = "http";
|
||||
};
|
||||
config.exports.prometheus = let
|
||||
exporterServices = filterAttrs (_: service: service.enable && service.prometheus.exporter.ports != []) config.exports.services;
|
||||
in {
|
||||
exporter.services = mkOptionDefault (attrNames exporterServices);
|
||||
};
|
||||
loki = {config, ...}: {
|
||||
id = mkAlmostOptionDefault "loki";
|
||||
nixos = {
|
||||
serviceAttr = "loki";
|
||||
assertions = mkIf config.enable [
|
||||
(nixosConfig: {
|
||||
assertion = config.ports.default.port == nixosConfig.services.loki.settings.httpListenPort;
|
||||
message = "port mismatch";
|
||||
})
|
||||
];
|
||||
};
|
||||
ports.default = mapAlmostOptionDefaults {
|
||||
port = 9093;
|
||||
protocol = "http";
|
||||
};
|
||||
};
|
||||
promtail = {config, ...}: {
|
||||
id = mkAlmostOptionDefault "promtail";
|
||||
nixos = {
|
||||
serviceAttr = "promtail";
|
||||
assertions = mkIf config.enable [
|
||||
(nixosConfig: {
|
||||
assertion = config.ports.default.port == nixosConfig.services.promtail.settings.httpListenPort;
|
||||
message = "port mismatch";
|
||||
})
|
||||
];
|
||||
};
|
||||
ports.default = mapAlmostOptionDefaults {
|
||||
port = 9094;
|
||||
protocol = "http";
|
||||
} // {
|
||||
prometheus.exporter.enable = true;
|
||||
};
|
||||
};
|
||||
} // exporters;
|
||||
}
|
||||
config.exports.services =
|
||||
{
|
||||
prometheus = {config, ...}: {
|
||||
id = mkAlmostOptionDefault "prometheus";
|
||||
nixos = {
|
||||
serviceAttr = "prometheus";
|
||||
assertions = mkIf config.enable [
|
||||
(nixosConfig: {
|
||||
assertion = config.ports.default.port == nixosConfig.services.prometheus.port;
|
||||
message = "port mismatch";
|
||||
})
|
||||
];
|
||||
};
|
||||
ports.default = mapAlmostOptionDefaults {
|
||||
port = 9090;
|
||||
protocol = "http";
|
||||
};
|
||||
};
|
||||
grafana = {config, ...}: {
|
||||
id = mkAlmostOptionDefault "grafana";
|
||||
nixos = {
|
||||
serviceAttr = "grafana";
|
||||
assertions = mkIf config.enable [
|
||||
(nixosConfig: {
|
||||
assertion = config.ports.default.port == nixosConfig.services.grafana.settings.server.http_port;
|
||||
message = "port mismatch";
|
||||
})
|
||||
];
|
||||
};
|
||||
ports.default = mapAlmostOptionDefaults {
|
||||
port = 9092;
|
||||
protocol = "http";
|
||||
};
|
||||
};
|
||||
loki = {config, ...}: {
|
||||
id = mkAlmostOptionDefault "loki";
|
||||
nixos = {
|
||||
serviceAttr = "loki";
|
||||
assertions = mkIf config.enable [
|
||||
(nixosConfig: {
|
||||
assertion = config.ports.default.port == nixosConfig.services.loki.settings.httpListenPort;
|
||||
message = "port mismatch";
|
||||
})
|
||||
];
|
||||
};
|
||||
ports.default = mapAlmostOptionDefaults {
|
||||
port = 9093;
|
||||
protocol = "http";
|
||||
};
|
||||
};
|
||||
promtail = {config, ...}: {
|
||||
id = mkAlmostOptionDefault "promtail";
|
||||
nixos = {
|
||||
serviceAttr = "promtail";
|
||||
assertions = mkIf config.enable [
|
||||
(nixosConfig: {
|
||||
assertion = config.ports.default.port == nixosConfig.services.promtail.settings.httpListenPort;
|
||||
message = "port mismatch";
|
||||
})
|
||||
];
|
||||
};
|
||||
ports.default =
|
||||
mapAlmostOptionDefaults {
|
||||
port = 9094;
|
||||
protocol = "http";
|
||||
}
|
||||
// {
|
||||
prometheus.exporter.enable = true;
|
||||
};
|
||||
};
|
||||
}
|
||||
// exporters;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -146,9 +146,11 @@
|
|||
};
|
||||
in {
|
||||
options.exports = with lib.types; {
|
||||
defaultServices = mkEnableOption "common base services" // {
|
||||
default = config.type == "NixOS";
|
||||
};
|
||||
defaultServices =
|
||||
mkEnableOption "common base services"
|
||||
// {
|
||||
default = config.type == "NixOS";
|
||||
};
|
||||
services = mkOption {
|
||||
type = attrsOf (submoduleWith {
|
||||
modules = [serviceModule];
|
||||
|
|
@ -170,7 +172,7 @@ in {
|
|||
"sshd"
|
||||
"prometheus-exporters-node"
|
||||
"promtail"
|
||||
] (_: { enable = mkAlmostOptionDefault true; });
|
||||
] (_: {enable = mkAlmostOptionDefault true;});
|
||||
in {
|
||||
services = mkIf cfg.defaultServices defaultServices;
|
||||
};
|
||||
|
|
|
|||
|
|
@ -1,6 +1,6 @@
|
|||
_: {
|
||||
services = {
|
||||
prometheus.exporters.node.enable = true;
|
||||
promtail.enable = true;
|
||||
};
|
||||
services = {
|
||||
prometheus.exporters.node.enable = true;
|
||||
promtail.enable = true;
|
||||
};
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,7 +1,7 @@
|
|||
_: {
|
||||
services = {
|
||||
grafana.enable = true;
|
||||
loki.enable = true;
|
||||
prometheus.enable = true;
|
||||
};
|
||||
}
|
||||
services = {
|
||||
grafana.enable = true;
|
||||
loki.enable = true;
|
||||
prometheus.enable = true;
|
||||
};
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue