2022-03-30 09:31:56 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.services.journald;
|
|
|
|
in {
|
2024-01-13 08:15:51 +00:00
|
|
|
imports = [
|
|
|
|
(mkRenamedOptionModule [ "services" "journald" "enableHttpGateway" ] [ "services" "journald" "gateway" "enable" ])
|
|
|
|
];
|
|
|
|
|
2022-03-30 09:31:56 +00:00
|
|
|
options = {
|
|
|
|
services.journald.console = mkOption {
|
|
|
|
default = "";
|
|
|
|
type = types.str;
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc "If non-empty, write log messages to the specified TTY device.";
|
2022-03-30 09:31:56 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
services.journald.rateLimitInterval = mkOption {
|
|
|
|
default = "30s";
|
|
|
|
type = types.str;
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2022-03-30 09:31:56 +00:00
|
|
|
Configures the rate limiting interval that is applied to all
|
|
|
|
messages generated on the system. This rate limiting is applied
|
|
|
|
per-service, so that two services which log do not interfere with
|
|
|
|
each other's limit. The value may be specified in the following
|
|
|
|
units: s, min, h, ms, us. To turn off any kind of rate limiting,
|
|
|
|
set either value to 0.
|
|
|
|
|
2022-08-12 12:06:08 +00:00
|
|
|
See {option}`services.journald.rateLimitBurst` for important
|
2022-03-30 09:31:56 +00:00
|
|
|
considerations when setting this value.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2023-11-16 04:20:00 +00:00
|
|
|
services.journald.storage = mkOption {
|
|
|
|
default = "persistent";
|
|
|
|
type = types.enum [ "persistent" "volatile" "auto" "none" ];
|
|
|
|
description = mdDoc ''
|
|
|
|
Controls where to store journal data. See
|
|
|
|
{manpage}`journald.conf(5)` for further information.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2022-03-30 09:31:56 +00:00
|
|
|
services.journald.rateLimitBurst = mkOption {
|
|
|
|
default = 10000;
|
|
|
|
type = types.int;
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2022-03-30 09:31:56 +00:00
|
|
|
Configures the rate limiting burst limit (number of messages per
|
|
|
|
interval) that is applied to all messages generated on the system.
|
|
|
|
This rate limiting is applied per-service, so that two services
|
|
|
|
which log do not interfere with each other's limit.
|
|
|
|
|
|
|
|
Note that the effective rate limit is multiplied by a factor derived
|
|
|
|
from the available free disk space for the journal as described on
|
2022-08-12 12:06:08 +00:00
|
|
|
[
|
|
|
|
journald.conf(5)](https://www.freedesktop.org/software/systemd/man/journald.conf.html).
|
2022-03-30 09:31:56 +00:00
|
|
|
|
|
|
|
Note that the total amount of logs stored is limited by journald settings
|
2024-02-07 01:22:34 +00:00
|
|
|
such as `SystemMaxUse`, which defaults to 10% the file system size
|
|
|
|
(capped at max 4GB), and `SystemKeepFree`, which defaults to 15% of the
|
|
|
|
file system size.
|
2022-03-30 09:31:56 +00:00
|
|
|
|
|
|
|
It is thus recommended to compute what period of time that you will be
|
|
|
|
able to store logs for when an application logs at full burst rate.
|
|
|
|
With default settings for log lines that are 100 Bytes long, this can
|
|
|
|
amount to just a few hours.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
services.journald.extraConfig = mkOption {
|
|
|
|
default = "";
|
|
|
|
type = types.lines;
|
|
|
|
example = "Storage=volatile";
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2022-03-30 09:31:56 +00:00
|
|
|
Extra config options for systemd-journald. See man journald.conf
|
|
|
|
for available options.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
services.journald.forwardToSyslog = mkOption {
|
|
|
|
default = config.services.rsyslogd.enable || config.services.syslog-ng.enable;
|
|
|
|
defaultText = literalExpression "services.rsyslogd.enable || services.syslog-ng.enable";
|
|
|
|
type = types.bool;
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2022-03-30 09:31:56 +00:00
|
|
|
Whether to forward log messages to syslog.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = {
|
|
|
|
systemd.additionalUpstreamSystemUnits = [
|
|
|
|
"systemd-journald.socket"
|
|
|
|
"systemd-journald@.socket"
|
|
|
|
"systemd-journald-varlink@.socket"
|
|
|
|
"systemd-journald.service"
|
|
|
|
"systemd-journald@.service"
|
|
|
|
"systemd-journal-flush.service"
|
|
|
|
"systemd-journal-catalog-update.service"
|
|
|
|
] ++ (optional (!config.boot.isContainer) "systemd-journald-audit.socket") ++ [
|
|
|
|
"systemd-journald-dev-log.socket"
|
|
|
|
"syslog.socket"
|
|
|
|
];
|
|
|
|
|
|
|
|
environment.etc = {
|
|
|
|
"systemd/journald.conf".text = ''
|
|
|
|
[Journal]
|
2023-11-16 04:20:00 +00:00
|
|
|
Storage=${cfg.storage}
|
2022-03-30 09:31:56 +00:00
|
|
|
RateLimitInterval=${cfg.rateLimitInterval}
|
|
|
|
RateLimitBurst=${toString cfg.rateLimitBurst}
|
|
|
|
${optionalString (cfg.console != "") ''
|
|
|
|
ForwardToConsole=yes
|
|
|
|
TTYPath=${cfg.console}
|
|
|
|
''}
|
|
|
|
${optionalString (cfg.forwardToSyslog) ''
|
|
|
|
ForwardToSyslog=yes
|
|
|
|
''}
|
|
|
|
${cfg.extraConfig}
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
users.groups.systemd-journal.gid = config.ids.gids.systemd-journal;
|
|
|
|
|
|
|
|
systemd.services.systemd-journal-flush.restartIfChanged = false;
|
|
|
|
systemd.services.systemd-journald.restartTriggers = [ config.environment.etc."systemd/journald.conf".source ];
|
|
|
|
systemd.services.systemd-journald.stopIfChanged = false;
|
|
|
|
systemd.services."systemd-journald@".restartTriggers = [ config.environment.etc."systemd/journald.conf".source ];
|
|
|
|
systemd.services."systemd-journald@".stopIfChanged = false;
|
|
|
|
};
|
|
|
|
}
|