Add metrics host with Grafana and Prometheus

This commit is contained in:
fi 2023-08-07 00:58:45 +02:00
parent b7bae9e9de
commit d625f3f887
Signed by: fi
SSH key fingerprint: SHA256:d+6fQoDPMbSFK95zRVflRKZLRKF4cPSQb7VIxYkhFsA
6 changed files with 36 additions and 10 deletions

View file

@ -10,7 +10,7 @@
outputs = { self, nixpkgs, nixpkgs-unstable, nixos-generators, ... }@inputs: let outputs = { self, nixpkgs, nixpkgs-unstable, nixos-generators, ... }@inputs: let
hosts = import ./hosts.nix inputs; hosts = import ./hosts.nix inputs;
helper = import ./helper.nix inputs; helper = import ./helper.nix inputs;
in { in {
colmena = { colmena = {
meta = { meta = {
@ -23,11 +23,15 @@
# The default is "nixpkgs" for "x86_64-linux" systems, # The default is "nixpkgs" for "x86_64-linux" systems,
# but it is overridden by the host-specific "hostNixpkgs" and "system" attributes. # but it is overridden by the host-specific "hostNixpkgs" and "system" attributes.
nodeNixpkgs = builtins.mapAttrs (name: host: host.pkgs) hosts; nodeNixpkgs = builtins.mapAttrs (name: host: host.pkgs) hosts;
specialArgs = {
inherit hosts;
};
}; };
} // builtins.mapAttrs (helper.generateColmenaHost) hosts; } // builtins.mapAttrs (helper.generateColmenaHost) hosts;
hydraJobs = { hydraJobs = {
nixConfigurations = builtins.mapAttrs (helper.generateNixConfiguration) hosts; nixConfigurations = builtins.mapAttrs (host: helper.generateNixConfiguration host { inherit hosts; }) hosts;
}; };
# Generate a base VM image for Proxmox with `nix build .#base-proxmox` # Generate a base VM image for Proxmox with `nix build .#base-proxmox`

View file

@ -14,7 +14,7 @@
imports = modules ++ nixpkgs.lib.optional (builtins.pathExists ./hosts/${name}/secrets.nix) ./hosts/${name}/secrets.nix; imports = modules ++ nixpkgs.lib.optional (builtins.pathExists ./hosts/${name}/secrets.nix) ./hosts/${name}/secrets.nix;
}; };
generateNixConfiguration = name: { generateNixConfiguration = name: specialArgs: {
hostNixpkgs, hostNixpkgs,
system, system,
modules, modules,
@ -26,6 +26,6 @@
filter = name: host: (builtins.substring 0 1 name) != "_"; filter = name: host: (builtins.substring 0 1 name) != "_";
in in
(nixpkgs.lib.filterAttrs filter (hostNixpkgs.lib.nixosSystem { (nixpkgs.lib.filterAttrs filter (hostNixpkgs.lib.nixosSystem {
inherit system modules; inherit system modules specialArgs;
})).config.system.build.toplevel; # Builds the entire NixOS system, see: https://nixos.org/manual/nixos/stable/#sec-building-parts })).config.system.build.toplevel; # Builds the entire NixOS system, see: https://nixos.org/manual/nixos/stable/#sec-building-parts
} }

View file

@ -1,11 +1,11 @@
{ ... }: { config, ... }:
{ {
services.grafana = { services.grafana = {
enable = true; enable = true;
settings = { settings = {
server = { server = {
domain = "grafana2.grzb.de"; domain = "grafana.grzb.de";
root_url = "https://grafana2.grzb.de"; root_url = "https://${config.services.grafana.settings.server.domain}";
}; };
security = { security = {
cookie_secure = true; cookie_secure = true;
@ -24,5 +24,13 @@
startTLS_policy = "NoStartTLS"; startTLS_policy = "NoStartTLS";
}; };
}; };
provision.datasources.settings.datasources = [
{
name = "Prometheus";
type = "prometheus";
url = "http://localhost:${builtins.toString config.services.prometheus.port}";
isDefault = true;
}
];
}; };
} }

View file

@ -3,7 +3,7 @@
services.nginx = { services.nginx = {
enable = true; enable = true;
virtualHosts = { virtualHosts = {
"grafana2.grzb.de" = { ${config.services.grafana.settings.server.domain} = {
forceSSL = true; forceSSL = true;
enableACME = true; enableACME = true;
listen = [ listen = [
@ -19,6 +19,7 @@
]; ];
locations."/" = { locations."/" = {
proxyPass = "http://${config.services.grafana.settings.server.http_addr}:${builtins.toString config.services.grafana.settings.server.http_port}"; proxyPass = "http://${config.services.grafana.settings.server.http_addr}:${builtins.toString config.services.grafana.settings.server.http_port}";
proxyWebsockets = true;
}; };
}; };
}; };

View file

@ -1,6 +1,19 @@
{ ... }: { hosts, ... }:
{ {
services.prometheus = { services.prometheus = {
enable = true; enable = true;
scrapeConfigs = [
{
job_name = "node";
static_configs = builtins.map (name: {
targets = [
"${name}.${hosts.${name}.site}.grzb.de:9100"
];
labels = {
host = "${name}.${hosts.${name}.site}.grzb.de";
};
}) (builtins.attrNames hosts);
}
];
}; };
} }

View file

@ -18,7 +18,7 @@
proxyPass = "http://netbox.vs.grzb.de:80"; proxyPass = "http://netbox.vs.grzb.de:80";
}; };
}; };
services.nginx.virtualHosts."grafana2.grzb.de" = { services.nginx.virtualHosts."grafana.grzb.de" = {
listen = [{ listen = [{
addr = "0.0.0.0"; addr = "0.0.0.0";
port = 80; port = 80;