These are the notes of a training course on systemd I gave as part of my work with Truelite.
There is quite a lot of material, so I split them into a series of posts, running once a day for the next 9 days.
Units
Everything managed by systemd is called a unit (see man systemd.unit),
and each unit is described by a configuration in ini-style format.
For example, this unit continuously plays an alarm sound when the system is in emergency or rescue mode:
[Unit]
Description=Beeps when in emergency or rescue mode
DefaultDependencies=false
StopWhenUnneeded=true
[Install]
WantedBy=emergency.target rescue.target
[Service]
Type=simple
ExecStart=/bin/sh -ec 'while true; do /usr/bin/aplay -q /tmp/beep.wav; sleep 2; done'
Units can be described by configuration files, which have different extensions based on what kind of thing they describe:
- .service: daemons
- .socket: communication sockets
- .device: hardware devices
- .mount: mount points
- .automount: automounting
- .swap: swap files or partitions
- .target: only dependencies, like Debian metapackages
- .path: inotify monitoring of paths
- .timer: cron-like activation
- .slice: group processes for common resource management
- .scope: group processes for common resource management
System unit files can be installed in:
- /lib/systemd/system/: for units provided by packaged software
- /run/systemd/system/: runtime-generated units
- /etc/systemd/system/: for units provided by systemd administrators
Unit files in /etc/ override unit files in /lib/. Note that while Debian
uses /lib/, other distributions may use /usr/lib/ instead.
If there is a directory with the same name as the unit file plus a .d suffix,
any file *.conf it contains is parsed after the unit, and can be used to add
or override configuration options.
For example:
- /lib/systemd/system/beep.service.d/foo.confcan be used to tweak the contents of- /lib/systemd/system/beep.service, so it is possible for a package to distribute a tweak to the configuration of another package.
- /etc/systemd/system/beep.service.d/foo.confcan be used to tweak the contents of- /lib/systemd/system/beep.service, so it is possible a system administrator to extend a packaged unit without needing to replace it entirely.
Similarly, a unitname.wants/ or unitname.requires/ directory can be used to
extend Wants= and Requires= dependencies on other units, by placing
symlinks to other units in them.
See also: