From: Lennart Poettering Date: Fri, 7 Dec 2018 15:49:52 +0000 (+0100) Subject: machined: flush nscd caches whenever a machine comes/goes X-Git-Tag: v240~44^2~2 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=9fdcbae5e200a7606f7eb1246c240d3f0cdd4f98;p=thirdparty%2Fsystemd.git machined: flush nscd caches whenever a machine comes/goes This way, nss-mymachines should always serve authoritative data. --- diff --git a/src/machine/machine.c b/src/machine/machine.c index 6af12765f5d..beb5b3566a9 100644 --- a/src/machine/machine.c +++ b/src/machine/machine.c @@ -398,6 +398,7 @@ int machine_start(Machine *m, sd_bus_message *properties, sd_bus_error *error) { machine_save(m); machine_send_signal(m, true); + (void) manager_enqueue_nscd_cache_flush(m->manager); return 0; } @@ -439,6 +440,7 @@ int machine_stop(Machine *m) { m->stopping = true; machine_save(m); + (void) manager_enqueue_nscd_cache_flush(m->manager); return r; } diff --git a/src/machine/machined-core.c b/src/machine/machined-core.c new file mode 100644 index 00000000000..6a404805eaf --- /dev/null +++ b/src/machine/machined-core.c @@ -0,0 +1,36 @@ +/* SPDX-License-Identifier: LGPL-2.1+ */ + +#include "machined.h" +#include "nscd-flush.h" +#include "strv.h" + +static int on_nscd_cache_flush_event(sd_event_source *s, void *userdata) { + /* Let's ask glibc's nscd daemon to flush its caches. We request this for the three database machines may show + * up in: the hosts database (for resolvable machine names) and the user and group databases (for the user ns + * ranges). */ + + (void) nscd_flush_cache(STRV_MAKE("passwd", "group", "hosts")); + return 0; +} + +int manager_enqueue_nscd_cache_flush(Manager *m) { + int r; + + assert(m); + + if (!m->nscd_cache_flush_event) { + r = sd_event_add_defer(m->event, &m->nscd_cache_flush_event, on_nscd_cache_flush_event, m); + if (r < 0) + return log_error_errno(r, "Failed to allocate NSCD cache flush event: %m"); + + sd_event_source_set_description(m->nscd_cache_flush_event, "nscd-cache-flush"); + } + + r = sd_event_source_set_enabled(m->nscd_cache_flush_event, SD_EVENT_ONESHOT); + if (r < 0) { + m->nscd_cache_flush_event = sd_event_source_unref(m->nscd_cache_flush_event); + return log_error_errno(r, "Failed to enable NSCD cache flush event: %m"); + } + + return 0; +} diff --git a/src/machine/machined.c b/src/machine/machined.c index 3ae57182dcc..9f23e369a46 100644 --- a/src/machine/machined.c +++ b/src/machine/machined.c @@ -77,6 +77,7 @@ static Manager* manager_unref(Manager *m) { hashmap_free(m->image_cache); sd_event_source_unref(m->image_cache_defer_event); + sd_event_source_unref(m->nscd_cache_flush_event); bus_verify_polkit_async_registry_free(m->polkit_registry); diff --git a/src/machine/machined.h b/src/machine/machined.h index ef63f96e971..2298a652c4d 100644 --- a/src/machine/machined.h +++ b/src/machine/machined.h @@ -35,6 +35,8 @@ struct Manager { LIST_HEAD(Operation, operations); unsigned n_operations; + + sd_event_source *nscd_cache_flush_event; }; int manager_add_machine(Manager *m, const char *name, Machine **_machine); @@ -53,3 +55,5 @@ int manager_kill_unit(Manager *manager, const char *unit, int signo, sd_bus_erro int manager_unref_unit(Manager *m, const char *unit, sd_bus_error *error); int manager_unit_is_active(Manager *manager, const char *unit); int manager_job_is_active(Manager *manager, const char *path); + +int manager_enqueue_nscd_cache_flush(Manager *m); diff --git a/src/machine/meson.build b/src/machine/meson.build index d5158771386..bc670714b45 100644 --- a/src/machine/meson.build +++ b/src/machine/meson.build @@ -9,6 +9,7 @@ libmachine_core_sources = files(''' machine.c machine.h machined-dbus.c + machined-core.c machine-dbus.c machine-dbus.h image-dbus.c