]> xenbits.xensource.com Git - libvirt.git/commitdiff
leaseshelper: Wait to acquire PID file
authorMichal Privoznik <mprivozn@redhat.com>
Thu, 11 Jun 2020 14:43:22 +0000 (16:43 +0200)
committerMichal Privoznik <mprivozn@redhat.com>
Wed, 24 Jun 2020 14:08:03 +0000 (16:08 +0200)
On a DHCP transaction, dnsmasq runs our leases helper which
updates corresponding JSON files. While one dnsmasq won't run the
leaseshelper in parallel, two dnsmasqs (from two distinct
networks) might. To avoid corrupting JSON file, the leaseshelper
acquires PID file first. Well, the way it's acquiring it is not
ideal - it calls virPidFileAcquirePath(wait = false); which
means, that either it acquires the PID file instantly or returns
an error and does not touch the JSON at all. This in turn means
that there might be a leases record missing. With wait = true,
this won't happen.

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

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
src/network/leaseshelper.c

index a1780ca4e4c9583e79756d6a45479aedfd2e7438..86c847db6dbef58829b74df94f764baca5310577 100644 (file)
@@ -160,7 +160,7 @@ main(int argc, char **argv)
     pid_file = g_strdup(RUNSTATEDIR "/leaseshelper.pid");
 
     /* Try to claim the pidfile, exiting if we can't */
-    if ((pid_file_fd = virPidFileAcquirePath(pid_file, false, getpid())) < 0)
+    if ((pid_file_fd = virPidFileAcquirePath(pid_file, true, getpid())) < 0)
         goto cleanup;
 
     /* Since interfaces can be hot plugged, we need to make sure that the