mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-03 11:35:19 +00:00
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:
parent
ee5c273ec5
commit
4e42686ade
@ -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,
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user