User Units
Dieser Artikel wurde für die folgenden Ubuntu-Versionen getestet:
Ubuntu 20.04 Focal Fossa
Du möchtest den Artikel für eine weitere Ubuntu-Version testen? Mitarbeit im Wiki ist immer willkommen! Dazu sind die Hinweise zum Testen von Artikeln zu beachten.
systemd User Units unterscheiden sich von "normalen" Units nur in so fern, dass die Units nicht beim Systemstart mit gestartet werden, sondern erst wenn der Nutzer, für den die Unit aktiviert ist, sich auf dem System anmeldet. Dabei spielt es keine Rolle, ob die Anmeldung lokal direkt am Rechner erfolgt oder von außerhalb, z.B. über SSH. Die Unit wird automatisch wieder beendet, wenn der Nutzer vom System vollständig abgemeldet ist.
Ein Beispiel für eine User Unit - welche auch standardmäßig bei Ubuntu aktiviert ist - ist das Löschen aller temporärer Dateien, die vom System angelegt werden, so lange ein Nutzer angemeldet ist.
Benutzung¶
User Units funktionieren grundsätzlich genau so wie systemweite Units, auch die entsprechenden Unit-Dateien sind identisch aufgebaut. Details hierzu sind im Wikiartikel systemd/Units zu finden.
User Units laufen standardmäßig mit den Rechten des Nutzer, für den die Unit gestartet wird.
Sichtbarkeit für andere Nutzer¶
Auch, wenn eine User Unit beim Anmelden für einen Nutzer gestartet wird, läuft die Unit nicht exklusiv oder gekapselt für diesen Nutzer. Startet man z.B. den im Unit Howto genutzten Server als User Unit, können auch alle anderen am System angemeldeten Nutzer auf den Server zugreifen.
Programme mit grafischer Oberfläche Starten¶
systemd ist grundsätzlich dafür gemacht, Dienste und Prozesse im Hintergrund zu starten. Es ist nicht dafür gemacht, Programme mit grafischer Oberfläche im Vordergrund zu starten. Technisch ist dies zwar über ein paar "Umwege" möglich, aber der bessere Weg zum Starten von grafischen Programmen nach dem Anmelden im System sind nach wie vor die Autostart-Mechanismen der verschiedenen Desktopumgebungen.
Speicherorte¶
Dateien für User Units können unter Ubuntu an vielen Stellen im Dateisystem abgelegt werden, der folgende Befehl listet diese Ordner auf:
systemd-analyze --user unit-paths
Die wichtigsten und häufig verwendeten Orte sind:
/usr/lib/systemd/user: Hier liegen alle vorinstallierten Dateien für User Units, die von allen Benutzern verwendet werden können.
/etc/systemd/user: Hier liegen Units, welche selber angelegt wurden und für jeden Nutzer des Systems aktiviert werden können. Für das Anlegen oder Editieren von Units in diesem Verzeichnis sind Root-Rechte notwendig.[2]
~/.local/share/systemd/user: Hier liegen Units von Paketen, die lokal nur für den einzelnen Benutzer installiert sind.
~/.config/systemd/user: Hier liegen alle Dateien von User Units, welche durch den jeweiligen Benutzer selbst angelegt oder editiert wurden. Änderungen sind nur für Units in /usr/lib/systemd/user möglich, nicht für systemweite Units. Da die entsprechenden Dateien unterhalb des Homeverzeichnisses des Benutzers liegen, sind hierfür keine Root-Rechte erforderlich.
Die Priorität von Units im Homeverzeichnis ist höher als die in den systemweiten Verzeichnissen, d.h. gibt es eine gleichnamige Unit z.B. in /etc/systemd/user und ~/.config/systemd/user, dann hat die in letzterem Verzeichnis die höhere Priorität und wird geladen.
eigene User Units anlegen¶
Das Anlegen eigener User Units erfolgt genau so wie im systemctl-Artikel beschrieben, es gelten die gleiche Sektionen und Direktiven in den verschiedenen Units. In der [Install]
-Sektion der Unit wird üblicherweise (aber nicht zwingender Weise) WantedBy=default.target
angegeben, da alle anderen, früheren Targets, in der Regel bereits erreicht sind, wenn man sich als Nutzer anmelden kann.
Das Aktivieren, Deaktivieren etc. von User Units erfolgt ebenfalls mittels systemctl, aber man benötigt keine Root-Rechte, fügt dafür aber die Option --user
hinzu. Der folgende Befehl
systemctl --user enable meine_unit.service
würde z.B. die Service-Unit meine_unit
als User Unit aktivieren.
Interaktion mit System Units¶
In der Standardkonfiguration werden User Units erst gestartet, wenn alle System Units bereits laufen, weil sich der Nutzer erst anmelden kann, wenn das System komplett gestartet ist. Von daher machen Direktiven wie After=...
auf bestimmte Units oder Targets, die beim Starten des Systems abgearbeitet werden, in der Regel keinen Sinn.
Des Weiteren werden beim Herunterfahren des Systems erst die User Units beendet, bevor die System Units abgearbeitet werden bzw. Targets des Herunterfahrens erreicht werden. Von daher machen auch Direktiven auf solche Targets in User Units in der Regel keinen Sinn.
Man kann das Verhalten von User Units aber mit enable-linger oder die Anpassung des Werts KillUserProcesses=...
in der Konfigurationsdatei logind.conf 🇬🇧 ändern.
Umgebungsvariablen¶
Auch, wenn User Units erst beim Anmelden ausgeführt werden, liest systemd nicht die Konfigurationsdateien des Nutzers wie z.B. .bashrc ein. Damit haben die gestarteten Prozesse auch keinen Zugriff auf die Umgebungsvariablen des Nutzer. Werden Umgebungsvariablen benötigt, so sind diese wie im Artikel systemd/Umgebungsvariable beschrieben zu setzen.
Logs zu User Units¶
User Units schreiben standardmäßig ihre Ausgaben / Logs ebenfalls über journald: in den systemweiten Log. Um die Logs von den eigenen User Units gezielt abzufragen, ruft man journalctl ebenfalls mit der Option --user
auf:
journalctl --user
Ansonsten gelten die gleichen Optionen wie im journalctl Wikiartikel beschrieben.
User Units ohne Anmeldung starten¶
Besteht die Notwendigkeit, dass für einen Nutzer User Units beim Systemstart - also ohne Anmeldung des Nutzers am System - gestartet werden bzw. User Units auch nach dem Abmelden weiterlaufen statt beendet werden, ist dies über systemd loginctl 🇬🇧 möglich.
Der folgende Befehl aktiviert dieses Verhalten für den Nutzer NUTZER
[1][2]
sudo loginctl enable-linger NUTZER
Deaktiviert wird es über:
sudo loginctl disable-linger NUTZER
Beispiele¶
Automatisches Starten einer graphischen Anwendung¶
Folgende Units bewirken das Vermeiden der Entkopplung von Signal Desktop ca. alle 10 Tage.
~/.config/systemd/user/signal-desktop.service :
[Unit] Description=Start Signal Desktop GUI Requires=default.target [Service] Type=forking ExecStart=/usr/bin/gtk-launch signal-desktop [Install]
Dateiname des Starters (ohne .desktop
) in /usr/share/applications/.
~/.config/systemd/user/signal-desktop.timer :
[Unit] Description=Timer for Signal Desktop GUI [Timer] OnCalendar=*-*-3/10 05:00:00 Persistent=true Unit=signal-desktop.service [Install] WantedBy=default.target
Aktivierung:
systemctl --user enable signal-desktop.timer systemctl --user start signal-desktop.timer # nur nötig, wenn der Timer sofort, also schon vor dem nächsten Ab-/Anmelden, loslegen soll.
Links¶
systemd - Übersicht über die systemd Artikel hier im Wiki
Artikel im Arch Wiki zu User Units