Make systemd unit ordering more robust

Since libvirt-guests script/service can operate on various URIs and we do
support both socket activation and traditional services, the ordering should be
specified for all the possible sockets and services.

Also remove the Wants= dependency since do not want to start any service.  We
cannot know which one libvirt-guests is configured, so we'd have to start all
the daemons which would break if unused colliding services are not
masked (libvirtd.service in the modular case and all the modular daemon service
units in the monolithic scenario).  Fortunately we can assume that the system is
configured properly to start services/sockets that are of interest to the user.
That also works with the setup described in https://libvirt.org/daemons.html .

To make it even more robust we add the daemon service into the machine units
created for individual domains as it was missing there.

https://bugzilla.redhat.com/show_bug.cgi?id=1868537

Signed-off-by: Martin Kletzander <mkletzan@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
Martin Kletzander 2022-02-14 12:37:37 +01:00
parent ee5c273ec5
commit 4e42686ade
2 changed files with 17 additions and 3 deletions

View File

@ -441,8 +441,10 @@ int virSystemdCreateMachine(const char *name,
nicindexes, nnicindexes, sizeof(int)); nicindexes, nnicindexes, sizeof(int));
gprops = g_variant_new_parsed("[('Slice', <%s>)," gprops = g_variant_new_parsed("[('Slice', <%s>),"
" ('After', <['libvirtd.service']>)," " ('After', <['libvirtd.service']>),"
" ('After', <['virt%sd.service']>),"
" ('Before', <['virt-guest-shutdown.target']>)]", " ('Before', <['virt-guest-shutdown.target']>)]",
slicename); slicename,
drivername);
message = g_variant_new("(s@ayssus@ai@a(sv))", message = g_variant_new("(s@ayssus@ai@a(sv))",
name, name,
guuid, guuid,
@ -489,8 +491,10 @@ int virSystemdCreateMachine(const char *name,
uuid, 16, sizeof(unsigned char)); uuid, 16, sizeof(unsigned char));
gprops = g_variant_new_parsed("[('Slice', <%s>)," gprops = g_variant_new_parsed("[('Slice', <%s>),"
" ('After', <['libvirtd.service']>)," " ('After', <['libvirtd.service']>),"
" ('After', <['virt%sd.service']>),"
" ('Before', <['virt-guest-shutdown.target']>)]", " ('Before', <['virt-guest-shutdown.target']>)]",
slicename); slicename,
drivername);
message = g_variant_new("(s@ayssus@a(sv))", message = g_variant_new("(s@ayssus@a(sv))",
name, name,
guuid, guuid,

View File

@ -1,10 +1,20 @@
[Unit] [Unit]
Description=Suspend/Resume Running libvirt Guests Description=Suspend/Resume Running libvirt Guests
Wants=libvirtd.service
Requires=virt-guest-shutdown.target Requires=virt-guest-shutdown.target
After=network.target After=network.target
After=time-sync.target After=time-sync.target
After=libvirtd.socket
After=virtqemud.socket
After=virtlxcd.socket
After=virtvboxd.socket
After=virtvzd.socket
After=virtxend.socket
After=libvirtd.service After=libvirtd.service
After=virtqemud.service
After=virtlxcd.service
After=virtvboxd.service
After=virtvzd.service
After=virtxend.service
After=virt-guest-shutdown.target After=virt-guest-shutdown.target
Documentation=man:libvirt-guests(8) Documentation=man:libvirt-guests(8)
Documentation=https://libvirt.org Documentation=https://libvirt.org