Settings for systemd units

Systemd allows fine-grained customization of units by defining so-called properties. These properties or settings influence what a unit, such as a service, can or can not do. As their is a wide range of settings, this page has the goal to present them, including a quick reference to each of them.

SettingDescriptionAvailable since
CapabilityBoundingSetDefine what capabilities are allowed within the service unit21
DeviceAllowAllow access to a device208
DevicePolicyDefine level of access to devices in /dev208
ExecPathsDefine the paths from which programs can be executed231
InaccessiblePathsDefine paths that should not be accessible231
IPAccountingDefine if accounting on network packets and bytes should be used235
KeyringModeControls kernel session keyring and define what is available to the service235
LockPersonalityPrevent processes switching their personality, a kernel execution domain235
MemoryDenyWriteExecuteBlock creation or alteration of memory segments to become writable and executable as well231
NoExecPathsExclude paths from which programs can be executed231
NoNewPrivilegesPrevent processes from gaining new privileges187
PrivateDevicesOnly allow access to a subset of devices in /dev209
PrivateMountsProvides a separated mount namespace to the service239
PrivateNetworkDefines if access to the network interfaces of the host is possible33
PrivatePIDsDefine a new PID namespace for the process and its children257
PrivateTmpDefine new namespace for /tmp and /var/tmp directory1
PrivateUsersDefine a new user namespace for the process and its children232
ProcSubsetDefine the subset of access by unit to /proc247
ProtectClockLimit access to clock information245
ProtectControlGroupsLimit write access to control groups directory structure under /sys/fs/cgroup232
ProtectHomeDefine what level of access is possible to home directories214
ProtectHostnameDefines if hostname or NIS domain name can be changed242
ProtectKernelLogsDefine if service may read or write to the kernel log ring buffer244
ProtectKernelModulesDefine if kernel modules may be loaded232
ProtectKernelTunablesLimit access to Linux kernel tunables and make others read-only232
ProtectProcControl the 'hidepid' mount option to define what information from /proc is available247
ProtectSystemMark some file system paths as read-only214
ReadOnlyPathsDefine paths that can be accessed with read-only permissions231
ReadWritePathsDefine paths that can be opened to read from and write to new or existing files231
RemoveIPCDefines if System V and POSIX IPC objects by the user and group are removed upon stopping the service232
RestrictAddressFamiliesControl what socket address families can be used by a unit211
RestrictNamespacesControl if namespaces usage is allowed233
RestrictRealtimeLimit the ability to use realtime scheduling231
RestrictSUIDSGIDLimit the ability to use setuid/setgid bits on files242
RuntimeDirectoryModeSet the default file permissions for runtime directory, which is defined as RuntimeDirectory234
SecureBitsChange the behavior of Linux capabilities by setting the securebits flag of the prctl(2) syscall1
SocketBindAllowDefine which address families, transport protocols, and/or ports are allowed to bind() to a socket249
SocketBindDenyRestricts address families, transport protocols, and/or ports to bind() to a socket249
SystemCallArchitecturesRestrict the subset of CPU instructions209
SystemCallFilterDefine what syscalls are allowed or forbidden to be used by a process187
UMaskSet default umask for new files1