nixos-config/hosts/falkenstein/modules/monitoring/default.nix

134 lines
3.3 KiB
Nix
Raw Normal View History

2024-05-24 15:59:34 +02:00
{ config, ... }:
{
2024-05-31 14:48:41 +02:00
age.secrets."maxmind" = {
file = ../../../../secrets/shared/maxmind.age;
};
2024-05-31 23:01:59 +02:00
imports = [
./dmarc.nix
];
2024-05-31 14:51:58 +02:00
users.users."promtail".extraGroups = [ "caddy" "systemd-journal" ];
2024-05-24 15:59:34 +02:00
services.prometheus = {
exporters = {
node = {
enable = true;
enabledCollectors = [ "systemd" ];
};
};
};
2024-05-31 14:48:41 +02:00
services.geoipupdate = {
enable = true;
settings = {
AccountID = 1018346;
LicenseKey = config.age.secrets."maxmind".path;
EditionIDs = [
"GeoLite2-ASN"
"GeoLite2-City"
"GeoLite2-Country"
];
DatabaseDirectory = "/var/lib/GeoIP";
};
};
services.promtail = {
enable = true;
configuration = {
server = {
http_listen_port = 3031;
grpc_listen_port = 0;
};
positions = {
filename = "/tmp/positions.yaml";
};
clients = [{
url = "http://nuc.vpn.rfive.de:3030/loki/api/v1/push";
}];
scrape_configs = [
2024-05-31 14:51:58 +02:00
{
job_name = "journal";
journal = {
json = false;
max_age = "12h";
path = "/var/log/journal";
labels.job = "systemd-journal";
};
relabel_configs = [
{
source_labels = [ "__journal__systemd_unit" ];
target_label = "unit";
}
{
source_labels = [ "__journal__hostname" ];
target_label = "host";
}
{
source_labels = [ "__journal_priority_keyword" ];
target_label = "level";
}
{
source_labels = [ "__journal_syslog_identifier" ];
target_label = "syslog_identifier";
}
];
pipeline_stages = [
{
match = {
selector = ''{unit="promtail.servicel"}'';
action = "drop";
};
}
];
}
2024-05-31 14:48:41 +02:00
{
job_name = "caddy_access_log";
static_configs = [
{
targets = [ "localhost" ];
labels = {
job = "caddy_access_log";
agent = "caddy-promtail";
__path__ = "/var/log/caddy/*.log";
2024-06-06 20:50:33 +02:00
host = "falkenstein";
2024-05-31 14:48:41 +02:00
};
}
];
pipeline_stages = [
2024-05-31 14:51:58 +02:00
{
# remove :443 from matrix or rspamd logs
replace = {
expression = ".*(de:443).*";
replace = "de";
};
}
2024-05-31 14:48:41 +02:00
{
json.expressions.remote_ip = "request.remote_ip";
}
{
geoip = {
db = "/var/lib/GeoIP/GeoLite2-City.mmdb";
source = "remote_ip";
db_type = "city";
};
}
2024-06-06 20:50:33 +02:00
{
geoip = {
db = "/var/lib/GeoIP/GeoLite2-ASN.mmdb";
source = "remote_ip";
db_type = "asn";
};
}
{
labeldrop = [
"geoip_subdivision_code"
"geoip_continent_code"
];
}
2024-05-31 14:48:41 +02:00
];
}
];
};
};
2024-05-24 15:59:34 +02:00
networking.firewall.allowedTCPPorts = [
config.services.prometheus.exporters.node.port
];
}