From: xujing Date: Wed, 16 Oct 2024 07:19:09 +0000 (+0800) Subject: pid1: add env var to override default mount rate limit interval X-Git-Tag: v257-rc1~205 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=cc2030f928981947db8fb9ec185a82024abab2c4;p=thirdparty%2Fsystemd.git pid1: add env var to override default mount rate limit interval Similar to 24a4542c. 24a4542c can only be set 1 in 1s at most, sometimes we may need to set to something else(such as 1 in 2s). So it's best to let the user decide. This also allows users to solve #34690. --- diff --git a/docs/ENVIRONMENT.md b/docs/ENVIRONMENT.md index f6f1216c054..cf5fb91eb96 100644 --- a/docs/ENVIRONMENT.md +++ b/docs/ENVIRONMENT.md @@ -351,6 +351,13 @@ All tools: default is not appropriate for a given system. Defaults to `5`, accepts positive integers. +* `$SYSTEMD_DEFAULT_MOUNT_RATE_LIMIT_INTERVAL_SEC` — can be set to override the mount + units interval rate limit for parsing `/proc/self/mountinfo`. Similar to + `$SYSTEMD_DEFAULT_MOUNT_RATE_LIMIT_BURST`, the interval limit maybe adjusted when + the default is not appropriate for a given system. The default value is 1 and the + default application time unit is second, and the time unit can beoverriden as usual + by specifying it explicitly, see the systemd.time(7) man page. + `systemd-remount-fs`: * `$SYSTEMD_REMOUNT_ROOT_RW=1` — if set and no entry for the root directory diff --git a/src/core/mount.c b/src/core/mount.c index 0a403b67592..19dd09c58fd 100644 --- a/src/core/mount.c +++ b/src/core/mount.c @@ -1997,6 +1997,7 @@ static void mount_enumerate(Manager *m) { mnt_init_debug(0); if (!m->mount_monitor) { + usec_t mount_rate_limit_interval = 1 * USEC_PER_SEC; unsigned mount_rate_limit_burst = 5; int fd; @@ -2038,14 +2039,21 @@ static void mount_enumerate(Manager *m) { } /* Let users override the default (5 in 1s), as it stalls the boot sequence on busy systems. */ - const char *e = secure_getenv("SYSTEMD_DEFAULT_MOUNT_RATE_LIMIT_BURST"); + const char *e = secure_getenv("SYSTEMD_DEFAULT_MOUNT_RATE_LIMIT_INTERVAL_SEC"); + if (e) { + r = parse_sec(e, &mount_rate_limit_interval); + if (r < 0) + log_debug_errno(r, "Invalid value in $SYSTEMD_DEFAULT_MOUNT_RATE_LIMIT_INTERVAL_SEC, ignoring: %s", e); + } + + e = secure_getenv("SYSTEMD_DEFAULT_MOUNT_RATE_LIMIT_BURST"); if (e) { r = safe_atou(e, &mount_rate_limit_burst); if (r < 0) - log_debug("Invalid value in $SYSTEMD_DEFAULT_MOUNT_RATE_LIMIT_BURST, ignoring: %s", e); + log_debug_errno(r, "Invalid value in $SYSTEMD_DEFAULT_MOUNT_RATE_LIMIT_BURST, ignoring: %s", e); } - r = sd_event_source_set_ratelimit(m->mount_event_source, 1 * USEC_PER_SEC, mount_rate_limit_burst); + r = sd_event_source_set_ratelimit(m->mount_event_source, mount_rate_limit_interval, mount_rate_limit_burst); if (r < 0) { log_error_errno(r, "Failed to enable rate limit for mount events: %m"); goto fail;