make loki, promtail better

(better indices and so on)
This commit is contained in:
Ingolf Wagner 2024-05-15 22:54:12 +02:00
parent f328d740e0
commit 5fbe52eb11
No known key found for this signature in database
GPG key ID: 76BF5F1928B9618B
8 changed files with 81 additions and 19 deletions

View file

@ -46,16 +46,49 @@ in
{ {
job_name = "journal"; job_name = "journal";
journal = { journal = {
json = true;
max_age = "12h"; max_age = "12h";
labels.job = "systemd-journal";
}; };
relabel_configs = [ pipeline_stages = [
{ {
source_labels = [ "__journal__systemd_unit" ]; json.expressions = {
target_label = "unit"; transport = "_TRANSPORT";
unit = "_SYSTEMD_UNIT";
msg = "MESSAGE";
coredump_cgroup = "COREDUMP_CGROUP";
coredump_exe = "COREDUMP_EXE";
coredump_cmdline = "COREDUMP_CMDLINE";
coredump_uid = "COREDUMP_UID";
coredump_gid = "COREDUMP_GID";
};
} }
{ {
source_labels = [ "__journal__transport" ]; # Set the unit (defaulting to the transport like audit and kernel)
target_label = "transport"; template = {
source = "unit";
template = "{{if .unit}}{{.unit}}{{else}}{{.transport}}{{end}}";
};
}
{ labels.coredump_unit = "coredump_unit"; }
{
# Normalize session IDs (session-1234.scope -> session.scope) to limit number of label values
replace = {
source = "unit";
expression = "^(session-\\d+.scope)$";
replace = "session.scope";
};
}
{ labels.unit = "unit"; }
{
# Write the proper message instead of JSON
output.source = "msg";
}
];
relabel_configs = [
{
source_labels = [ "__journal__hostname" ];
target_label = "instance";
} }
]; ];
} }

View file

@ -62,7 +62,6 @@ with lib;
'"http_user_agent":"$http_user_agent"' '"http_user_agent":"$http_user_agent"'
'}'; '}';
# log to local journald # log to local journald
access_log syslog:server=unix:/dev/log,nohostname logfmt; access_log syslog:server=unix:/dev/log,nohostname logfmt;
''; '';

View file

@ -2,19 +2,22 @@
with lib; with lib;
let let
configuration = { configuration = {
Chaospott37C3Tickets = rec {
url = "https://md.chaospott.de/171s8-_cQCyX_tUca_Jxqw/download"; #Chaospott37C3Tickets = rec {
target = "/media/curl/37C3"; # url = "https://md.chaospott.de/171s8-_cQCyX_tUca_Jxqw/download";
options = [ # target = "/media/curl/37C3";
"-o $( date +%H:%M:%S )-TicketPlaning.md" # options = [
]; # "-o $( date +%H:%M:%S )-TicketPlaning.md"
}; # ];
#};
StableConfussion = { StableConfussion = {
url = "http://stable-confusion.r/outputs/"; url = "http://stable-confusion.r/outputs/";
target = "/media/curl/stable-confusion"; target = "/media/curl/stable-confusion";
options = [ "--mirror" ]; options = [ "--mirror" "--quiet" ];
command = "wget"; command = "wget";
}; };
}; };
downloadScript = downloadScript =

View file

@ -8,6 +8,7 @@
PAPERLESS_OCR_LANGUAGE = "deu+eng"; PAPERLESS_OCR_LANGUAGE = "deu+eng";
PAPERLESS_APP_TITLE = "paperless.chungus.private"; PAPERLESS_APP_TITLE = "paperless.chungus.private";
PAPERLESS_CONSUMER_IGNORE_PATTERN = builtins.toJSON [ ".DS_STORE/*" "desktop.ini" ]; PAPERLESS_CONSUMER_IGNORE_PATTERN = builtins.toJSON [ ".DS_STORE/*" "desktop.ini" ];
PAPERLESS_EMAIL_TASK_CRON = "0 */8 * * *"; # “At minute 0 past every 8th hour.”
#PAPERLESS_CONSUMER_DELETE_DUPLICATES = true; #PAPERLESS_CONSUMER_DELETE_DUPLICATES = true;
}; };
}; };

View file

@ -3,6 +3,7 @@
sops.secrets.rsync_private_key = { }; sops.secrets.rsync_private_key = { };
rbackup.plans = { rbackup.plans = {
# todo : syncoid
nextcloud = { nextcloud = {
sshKeyPath = config.sops.secrets.rsync_private_key.path; sshKeyPath = config.sops.secrets.rsync_private_key.path;
src = "root@orbi:/var/lib/nixos-containers/nextcloud"; src = "root@orbi:/var/lib/nixos-containers/nextcloud";

View file

@ -8,6 +8,8 @@
services.syncoid = { services.syncoid = {
enable = true; enable = true;
# local
commands.service2 = { commands.service2 = {
source = "zroot/services2"; source = "zroot/services2";
target = "zraid/mirror/services2"; # should not be created up front! target = "zraid/mirror/services2"; # should not be created up front!
@ -20,6 +22,8 @@
source = "zroot/postgresql"; source = "zroot/postgresql";
target = "zraid/mirror/postgresql"; # should not be created up front! target = "zraid/mirror/postgresql"; # should not be created up front!
}; };
# remote
commands.photoprism = { commands.photoprism = {
sshKey = config.sops.secrets.syncoid_private_key.path; sshKey = config.sops.secrets.syncoid_private_key.path;
source = "root@orbi:zmedia/photoprism"; source = "root@orbi:zmedia/photoprism";

View file

@ -1,17 +1,38 @@
{ config, pkgs, ... }: { config, pkgs, ... }:
{ {
services.opentelemetry-collector.settings = { services.opentelemetry-collector.settings = {
exporters.loki = { exporters.loki = {
endpoint = "http://127.0.0.1:3100/loki/api/v1/push"; endpoint = "http://127.0.0.1:3100/loki/api/v1/push";
default_labels_enabled = {
exporter = true;
job = true;
instance = true;
level = true;
};
};
processors = {
attributes.actions = [
{
action = "insert";
key = "loki.attribute.labels";
value = "job, unit";
}
];
resource.attributes = [{
action = "insert";
key = "loki.resource.labels";
value = "host.name";
}];
}; };
service.pipelines.logs.exporters = [ "loki" ]; service.pipelines.logs.exporters = [ "loki" ];
service.pipelines.logs.processors = [ "resource" "attributes" ];
}; };
services.loki = { services.loki = {
enable = true; enable = true;
configuration = { configuration = {
server = { server = {
http_listen_port = 3100; http_listen_port = 3100;
log_level = "warn"; log_level = "warn";