InaccessiblePaths setting
This article has last been updated at .
The property InaccessiblePaths is a systemd unit setting used for sandboxing. It is available since systemd 231.
Purpose: define paths that should not be accessible
New to securing and tuning systemd services? Start with the how to harden a systemd service unit article to learn tuning step-by-step, including the usage of relevant tools.
Why and when to use InaccessiblePaths
Systemd has the unit setting InaccessiblePaths to define paths that should never be accessible. Instead of using the principles of an allow list, it is an explicit deny list. It can be used to block access by a process to a location with sensitive data or a path commonly misused for exploits.
Values
Define the paths that should never be allowed access.
[Service]
InaccessiblePaths=/dev/shm
- When a path is prefixed with a minus (-), it is ignored if it does not exist
- When a path is prefixed with a plus (+), the path is considered relative to root of directory (e.g. configured with RootDirectory)
Generic advice
This setting is not as powerful as others that can make larger parts of the system inaccessible, while defining just a few paths that still should be. In may still be useful when there is a need to block a very sensitive path. A good example for this is when using the MemoryDenyWriteExecute setting.
Related hardening profiles
The systemd unit setting InaccessiblePaths is used in the following systemd hardening profiles. These hardening profiles help improving security of common Linux services and usually require minimal tuning.