mirror of
https://github.com/systemd/systemd-stable.git
synced 2024-12-22 13:33:56 +03:00
13d0b19d4e
Prompted by https://bugzilla.redhat.com/show_bug.cgi?id=1927148 and https://bugzilla.redhat.com/show_bug.cgi?id=1931181. Adds condition check for cgroups v2 and PSI, which systemd-oomd cannot start without.
59 lines
1.6 KiB
SYSTEMD
59 lines
1.6 KiB
SYSTEMD
# SPDX-License-Identifier: LGPL-2.1-or-later
|
|
#
|
|
# This file is part of systemd.
|
|
#
|
|
# systemd is free software; you can redistribute it and/or modify it
|
|
# under the terms of the GNU Lesser General Public License as published by
|
|
# the Free Software Foundation; either version 2.1 of the License, or
|
|
# (at your option) any later version.
|
|
|
|
[Unit]
|
|
Description=Userspace Out-Of-Memory (OOM) Killer
|
|
Documentation=man:systemd-oomd.service(8)
|
|
DefaultDependencies=no
|
|
Before=multi-user.target shutdown.target
|
|
Conflicts=shutdown.target
|
|
ConditionControlGroupController=v2
|
|
ConditionPathExists=/proc/pressure/cpu
|
|
ConditionPathExists=/proc/pressure/io
|
|
ConditionPathExists=/proc/pressure/memory
|
|
|
|
[Service]
|
|
AmbientCapabilities=CAP_KILL CAP_DAC_OVERRIDE
|
|
BusName=org.freedesktop.oom1
|
|
CapabilityBoundingSet=CAP_KILL CAP_DAC_OVERRIDE
|
|
ExecStart=@rootlibexecdir@/systemd-oomd
|
|
IPAddressDeny=any
|
|
LockPersonality=yes
|
|
MemoryDenyWriteExecute=yes
|
|
# Reserve some minimum amount of memory so that systemd-oomd can continue to
|
|
# run in resource starved scenarios.
|
|
MemoryMin=64M
|
|
MemoryLow=64M
|
|
NoNewPrivileges=yes
|
|
OOMScoreAdjust=-900
|
|
PrivateDevices=yes
|
|
PrivateTmp=yes
|
|
ProtectClock=yes
|
|
ProtectHome=yes
|
|
ProtectHostname=yes
|
|
ProtectKernelLogs=yes
|
|
ProtectKernelModules=yes
|
|
ProtectKernelTunables=yes
|
|
ProtectSystem=strict
|
|
Restart=on-failure
|
|
RestrictAddressFamilies=AF_UNIX
|
|
RestrictNamespaces=yes
|
|
RestrictRealtime=yes
|
|
RestrictSUIDSGID=yes
|
|
SystemCallArchitectures=native
|
|
SystemCallErrorNumber=EPERM
|
|
SystemCallFilter=@system-service
|
|
Type=notify
|
|
User=systemd-oom
|
|
@SERVICE_WATCHDOG@
|
|
|
|
[Install]
|
|
WantedBy=multi-user.target
|
|
Alias=dbus-org.freedesktop.oom1.service
|