infra/nix/hosts/z/modules/promtail/promtail.nix
2026-01-05 23:09:19 +01:00

82 lines
2.2 KiB
Nix

{
config,
lib,
pkgs,
...
}: {
sops = {
templates = {
promtail.content = ''
server:
http_listen_port: 28183
grpc_listen_port: 0
disable: true
positions:
# filename: /tmp/positions.yaml
filename: /var/tmp/positions.yaml
clients:
- url: https://logs.${config.sops.placeholder.domainName}/loki/api/v1/push
tenant_id: ""
backoff_config:
min_period: 1000ms
max_period: 5m
max_retries: 10000
scrape_configs:
- job_name: journal
journal:
#max_age: 168h
# max_age: 968h
#max_age: 1440h
max_age: 14400h
labels:
job: systemd-journal
relabel_configs:
- source_labels: ["__journal__systemd_unit"]
target_label: "unit"
- source_labels: ['__journal__hostname']
target_label: nodename
- source_labels: ['__journal_syslog_identifier']
target_label: syslog_identifier
# drop these because of excessive logging
- action: drop
regex: '.*tailscale.*'
source_labels: ['__journal__systemd_unit', 'unit']
- action: drop
regex: '.*zfs-zed.*'
source_labels: ['__journal__systemd_unit', 'unit', 'syslog_identifier']
- action: drop
regex: '.*zed.*'
source_labels: ['__journal__systemd_unit', 'unit', 'syslog_identifier']
'';
};
};
systemd = {
services = {
promtail = {
description = "Promtail service for Loki";
wantedBy = ["multi-user.target"];
serviceConfig = {
ExecStart = ''
${pkgs.grafana-loki}/bin/promtail --config.file ${config.sops.templates.promtail.path}
'';
TimeoutStopSec = "5s";
RestartSec = 90;
# Restart = "always";
Restart = "on-failure";
};
};
};
paths.promtail = {
pathConfig = {
PathChanged = config.sops.templates.promtail.path;
Unit = "promtail.service";
};
};
};
}