]> git.ipfire.org Git - thirdparty/libvirt.git/commitdiff
libvirtd: Explicit dependency on systemd-machined
authorMichal Koutný <mkoutny@suse.com>
Wed, 10 Jan 2018 22:06:41 +0000 (23:06 +0100)
committerCédric Bosdonnat <cbosdonnat@suse.com>
Mon, 22 Jan 2018 15:55:12 +0000 (16:55 +0100)
The libvirtd daemon uses systemd-machined D-Bus API when manipulating
domains. The systemd-machined is D-Bus activated on demand.

However, during system shutdown systemd-machined is stopped concurrently
with libvirtd and virsh users also doing their final cleanup may
transitively fail due to unavailability of systemd-machined. Example
error message

> libvirtd[1390]: 2017-12-20 18:55:56.182+0000: 32700: error : virSystemdTerminateMachine:503 : Refusing activation, D-Bus is shutting down.

To circumvent this we need to explicitly specify both ordering and
requirement dependency (to avoid late D-Bus activation) on
systemd-machined. See [1] for the dependency debate.

[1] https://lists.freedesktop.org/archives/systemd-devel/2018-January/040095.html

daemon/libvirtd.service.in

index c189f5e6532f958856802f07a976a3af9dbf5d21..769702ea756346e3a3123de2863d389e717c80a9 100644 (file)
@@ -7,6 +7,7 @@
 Description=Virtualization daemon
 Requires=virtlogd.socket
 Requires=virtlockd.socket
+Wants=systemd-machined.service
 Before=libvirt-guests.service
 After=network.target
 After=dbus.service
@@ -14,6 +15,7 @@ After=iscsid.service
 After=apparmor.service
 After=local-fs.target
 After=remote-fs.target
+After=systemd-machined.service
 Documentation=man:libvirtd(8)
 Documentation=https://libvirt.org