forked from Drift/pvv-nixos-config
Felix Albrigtsen
55e8f01d1d
This PR is made while moving Ildkule from PVE on joshua, to Openstack on stack.it.ntnu.no. - The main monitoring dashboard is moved from https://ildkule.pvv.ntnu.no to https://grafana.pvv.ntnu.no. - A new service is added: uptime-kuma on https://uptime.pvv.ntnu.no. - The (hardware) configuration for ildkule is updated to fit the new virtualization environment, boot loader, network interfaces, etc. - Metrics exporters on other hosts should be updated to allow connections from the new host As this is the first proper server running on openstack, and therefore outside our main IP range, we might discover challenges in our network structure. For example, the database servers usually only allow connections from this range, so Ildkule can no longer access it. This should be explored, documented and/or fixed as we move more services. Reviewed-on: Drift/pvv-nixos-config#36 Co-authored-by: Felix Albrigtsen <felix@albrigtsen.it> Co-committed-by: Felix Albrigtsen <felix@albrigtsen.it>
52 lines
1.6 KiB
Nix
52 lines
1.6 KiB
Nix
{ pkgs, lib, config, values, ... }: let
|
|
cfg = config.services.prometheus;
|
|
in {
|
|
sops.secrets = {
|
|
"keys/postgres/postgres_exporter_env" = {};
|
|
"keys/postgres/postgres_exporter_knakelibrak_env" = {};
|
|
};
|
|
|
|
services.prometheus = {
|
|
scrapeConfigs = [
|
|
{
|
|
job_name = "postgres";
|
|
scrape_interval = "15s";
|
|
static_configs = [{
|
|
targets = [ "localhost:${toString cfg.exporters.postgres.port}" ];
|
|
labels = {
|
|
server = "bicep";
|
|
};
|
|
}];
|
|
}
|
|
{
|
|
job_name = "postgres-knakelibrak";
|
|
scrape_interval = "15s";
|
|
static_configs = [{
|
|
targets = [ "localhost:${toString (cfg.exporters.postgres.port + 1)}" ];
|
|
labels = {
|
|
server = "knakelibrak";
|
|
};
|
|
}];
|
|
}
|
|
];
|
|
|
|
exporters.postgres = {
|
|
enable = true;
|
|
extraFlags = [ "--auto-discover-databases" ];
|
|
environmentFile = config.sops.secrets."keys/postgres/postgres_exporter_env".path;
|
|
};
|
|
};
|
|
|
|
systemd.services.prometheus-postgres-exporter-knakelibrak.serviceConfig = let
|
|
localCfg = config.services.prometheus.exporters.postgres;
|
|
in lib.recursiveUpdate config.systemd.services.prometheus-postgres-exporter.serviceConfig {
|
|
EnvironmentFile = config.sops.secrets."keys/postgres/postgres_exporter_knakelibrak_env".path;
|
|
ExecStart = ''
|
|
${pkgs.prometheus-postgres-exporter}/bin/postgres_exporter \
|
|
--web.listen-address ${localCfg.listenAddress}:${toString (localCfg.port + 1)} \
|
|
--web.telemetry-path ${localCfg.telemetryPath} \
|
|
${lib.concatStringsSep " \\\n " localCfg.extraFlags}
|
|
'';
|
|
};
|
|
}
|