From 563efc95e40dffef20a63174cb8ce398ef5d8c27 Mon Sep 17 00:00:00 2001 From: Max Date: Mon, 16 May 2022 00:09:41 +0200 Subject: [PATCH] modules/monitoring: ship journal logs to Loki --- modules/monitoring/default.nix | 47 +++++++++++++++++++++++++++++++++- 1 file changed, 46 insertions(+), 1 deletion(-) diff --git a/modules/monitoring/default.nix b/modules/monitoring/default.nix index 34a0c45..46e7ba9 100644 --- a/modules/monitoring/default.nix +++ b/modules/monitoring/default.nix @@ -1,8 +1,20 @@ -{ config, hosts, ... }: +{ config, hosts, lib, pkgs, ... }: let myNode = hosts.${config.networking.hostName}; + + writeJSON = filename: data: pkgs.writeText filename (builtins.toJSON data); + + inherit (config) ports portsStr; + + relabel = from: to: { + source_labels = [ from ]; + target_label = to; + }; in { + # same as remote loki port + reservePortsFor = [ "loki" ]; + services.prometheus.exporters = { node = { enable = true; @@ -15,4 +27,37 @@ in interval = "60s"; }; }; + + systemd.services.promtail = { + wantedBy = [ "multi-user.target" ]; + + serviceConfig = { + ExecStart = "${pkgs.grafana-loki}/bin/promtail --config.expand-env=true --config.file ${writeJSON "promtail.yaml" { + server.disable = true; + positions.filename = "\${STATE_DIRECTORY:/tmp}/promtail-positions.yaml"; + clients = [ + { url = "http://${hosts.VEGAS.hypr.addr}:${portsStr.loki}/loki/api/v1/push"; } + ]; + scrape_configs = [ + { + job_name = "journal"; + journal = { + max_age = "12h"; + labels.host = config.networking.hostName; + }; + relabel_configs = [ + (relabel "__journal__systemd_unit" "systemd_unit") + (relabel "__journal__hostname" "machine_name") + (relabel "__journal__exe" "executable") + (relabel "__journal__comm" "command") + (relabel "__journal__boot_id" "systemd_boot_id") + (relabel "__journal__systemd_cgroup" "systemd_cgroup") + (relabel "__journal_syslog_identifier" "syslog_identifier") + ]; + } + ]; + }}"; + StateDirectory = "promtail"; + }; + }; }