Systemd: Difference between revisions
Jump to navigation
Jump to search
Power management (
Line 7: | Line 7: | ||
systemctl # Show all loaded modules and their status |
systemctl # Show all loaded modules and their status |
||
systemctl status # Show all process and system status |
systemctl status # Show all process and system status |
||
systemctl list-dependencies # Show dependencies between units |
|||
journalctl -b # Kernel logs (incl. boot), with coloring |
journalctl -b # Kernel logs (incl. boot), with coloring |
Revision as of 10:25, 4 May 2020
References
Command-line interface
systemctl list-unit-files # List unit files installed and their status
systemctl # Show all loaded modules and their status
systemctl status # Show all process and system status
systemctl list-dependencies # Show dependencies between units
journalctl -b # Kernel logs (incl. boot), with coloring
Services
systemd:0
means first systemd socket defined in the .socket file (FD 3),systemd:1
is the second (FD 4) and so on.
Configure a service to start at boot
sudo systemctl enable courier-authdaemon
Create a new service
From SE:
- Create a file /etc/systemd/system/foo.service
[Unit]
Description=foo
[Service]
ExecStart=/bin/bash -c "while true; do /bin/inotifywait -qq --event close_write /sys/class/backlight/acpi_video0/brightness; su myusername -c '/bin/xbacklight -display :0 -set $(cat /sys/class/backlight/acpi_video0/brightness)'; done"
[Install]
WantedBy=multi-user.target
Reload systemd:
systemctl daemon-reload
Enable the new service:
systemctl enable foo
This will create a symlink in /etc/systemd/system/multi-user.target.wants/, that will trigger the start of the service at next boot.
To start it immediately:
systemctl start foo
systemctl status foo # optional, just to verify
Example of options to add in the service file:
[Unit]
Description=rapid spam filtering system
After=nss-lookup.target
[Service]
ExecStart=/usr/bin/rspamd -c /etc/rspamd/rspamd.conf -f
User=_rspamd
RuntimeDirectory=rspamd
RuntimeDirectoryMode=0755
Restart=always
[Install]
WantedBy=multi-user.target
Timers
Timers are a bit like cron job except they trigger systemd services, and have more scheduling and management options.
By default, a timer fires the service with the same name (see timer man page).
Power management (systemd-inhibit
)
systemd-inhibit may be used to execute a program with a shutdown, sleep, or idle inhibitor lock taken. It allows you do disable only selected features and allows setting user visible string to explain why these features are inhibited [1]. See man systemd-inhibit
systemd-inhibit sleep 2h # Prohibit idle, sleep, shutdown for 2 hours
systemd-inhibit wget "https://example.com/files/huge-download.dat" # Same, while download ongoing
To list active inhibitors:
systemd-inhibit --list