Skip to content
Snippets Groups Projects
prometheus.nix 3.38 KiB
Newer Older
# Prometheus server
#
# Scope: Pull data from our cluster machines into TSDB
# See https://christine.website/blog/prometheus-grafana-loki-nixos-2020-11-20

{ config, lib, ... }:
let

  exportersCfg = config.services.prometheus.exporters;
  cfg = config.services.private-storage.monitoring.prometheus;
  dropPortNumber = {
    source_labels = [ "__address__" ];
    regex = "^(.*)(?:\\.monitoringvpn):\\d+$";

in {
  options.services.private-storage.monitoring.prometheus = {
    nodeExporterTargets = lib.mkOption {
      type = with lib.types; listOf str;
      description = "List of nodes (hostnames or IPs) to scrape.";
    };
    nginxExporterTargets = lib.mkOption {
      type = with lib.types; listOf str;
      description = "List of nodes (hostnames or IPs) to scrape.";
    };
Florian Sesser's avatar
Florian Sesser committed
    paymentExporterTargets = lib.mkOption {
      type = with lib.types; listOf str;
Florian Sesser's avatar
Florian Sesser committed
      description = "List of nodes (hostnames or IPs) to scrape.";
    };
    blackboxExporterHttpsTargets = lib.mkOption {
      type = with lib.types; listOf str;
      example = [ "https://node1.com/" "https://node2.org/" ];
      description = "List of https URLs to scrape.";
    };
Florian Sesser's avatar
Florian Sesser committed
    # networking.firewall.allowedTCPPorts = [ services.prometheus.port ];

    services.prometheus = {
      enable = true;
Florian Sesser's avatar
Florian Sesser committed
      # port = 9090; # Option only in recent (20.09?) nixpkgs, 9090 default
      scrapeConfigs = [
        {
          job_name = "node-exporters";
          static_configs = [{
            targets = map (x: x + ":" + (toString exportersCfg.node.port)) cfg.nodeExporterTargets;
          }];
          relabel_configs = [ dropPortNumber ];
        }
        {
          job_name = "nginx-exporters";
          static_configs = [{
            targets = map (x: x + ":" + (toString exportersCfg.nginx.port)) cfg.nginxExporterTargets;
          }];
          relabel_configs = [ dropPortNumber ];
Florian Sesser's avatar
Florian Sesser committed
        {
          job_name = "payment-exporters";
          scheme = "https";
          tls_config.insecure_skip_verify = true;
          static_configs = [{
            # Explicitly setting the port number so the relabel_config can filter it out again.
            # Leaving it out makes the port number show in Grafana.
            targets = map (x: x + ":443") cfg.paymentExporterTargets;
Florian Sesser's avatar
Florian Sesser committed
          }];
          relabel_configs = [ dropPortNumber ];
        }
        {
          # The Blackbox exporter is using Prometheus' "Multi-Target Exporter Pattern",
          # see https://prometheus.io/docs/guides/multi-target-exporter/
          job_name = "blackboxExporterHttps";
          static_configs = [{
            targets = cfg.blackboxExporterHttpsTargets;
          }];
          metrics_path = "/probe";
          params.module = [ "https_2xx" ];
          relabel_configs = [
            {
              source_labels = [ "__address__" ];
              target_label = "__param_target";
            }
            {
              source_labels = [ "__param_target" ];
              target_label = "instance";
            }
            {
              source_labels = [];
              target_label = "__address__";
              # The blackbox exporter’s real hostname:port
              replacement = "monitoring:9115";
            }
          ];
        }