Sign Up
Log In
Log In
or
Sign Up
Places
All Projects
Status Monitor
Collapse sidebar
openSUSE:Step:FrontRunner
autofs.8664
autofs-5-1-3-check-map-instances-for-staleness-...
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
File autofs-5-1-3-check-map-instances-for-staleness-on-map-update.patch of Package autofs.8664
From: Ian Kent <raven@themaw.net> Subject: autofs-5.1.3 - check map instances for staleness on map update Patch-mainline: Submitted, https://www.spinics.net/lists/autofs/msg01707.html References: bsc#1038198 When there are multiple map source instances bypassing the cache update when any one of the map sources returns NSS_STATUS_UNAVAIL is too strong. When the map is marked not stale also check the instances before skipping the cache update. Signed-off-by: Ian Kent <raven@themaw.net> Acked-by: Jeff Mahoney <jeffm@suse.com> --- daemon/lookup.c | 5 +++-- daemon/state.c | 2 +- include/master.h | 1 + lib/master.c | 2 +- 4 files changed, 6 insertions(+), 4 deletions(-) diff --git a/daemon/lookup.c b/daemon/lookup.c index 569fffaf..cb67e7d9 100644 --- a/daemon/lookup.c +++ b/daemon/lookup.c @@ -633,7 +633,8 @@ int lookup_nss_read_map(struct autofs_point *ap, struct map_source *source, time if (result == NSS_STATUS_UNKNOWN) continue; - /* Don't try to update the map cache if it's unavailable */ + /* Try to avoid updating the map cache if an instance + * is unavailable */ if (result == NSS_STATUS_UNAVAIL) map->stale = 0; @@ -1453,7 +1454,7 @@ int lookup_prune_cache(struct autofs_point *ap, time_t age) map = entry->maps; while (map) { /* Is the map stale */ - if (!map->stale) { + if (!map->stale && !check_stale_instances(map)) { map = map->next; continue; } diff --git a/daemon/state.c b/daemon/state.c index cd0dd939..72bba6af 100644 --- a/daemon/state.c +++ b/daemon/state.c @@ -512,7 +512,7 @@ static void *do_readmap(void *arg) map = ap->entry->maps; while (map) { /* Is map source up to date or no longer valid */ - if (!map->stale) { + if (!map->stale && !check_stale_instances(map)) { map = map->next; continue; } diff --git a/include/master.h b/include/master.h index 087ddbe6..e1d272fb 100644 --- a/include/master.h +++ b/include/master.h @@ -97,6 +97,7 @@ struct map_source * master_find_source_instance(struct map_source *, const char *, const char *, int, const char **); struct map_source * master_add_source_instance(struct map_source *, const char *, const char *, time_t, int, const char **); +int check_stale_instances(struct map_source *); void clear_stale_instances(struct map_source *); void send_map_update_request(struct autofs_point *); void master_source_writelock(struct master_mapent *); diff --git a/lib/master.c b/lib/master.c index 142f97ed..22b1522a 100644 --- a/lib/master.c +++ b/lib/master.c @@ -521,7 +521,7 @@ master_add_source_instance(struct map_source *source, const char *type, const ch return new; } -static int check_stale_instances(struct map_source *source) +int check_stale_instances(struct map_source *source) { struct map_source *map;
Locations
Projects
Search
Status Monitor
Help
OpenBuildService.org
Documentation
API Documentation
Code of Conduct
Contact
Support
@OBShq
Terms
openSUSE Build Service is sponsored by
The Open Build Service is an
openSUSE project
.
Sign Up
Log In
Places
Places
All Projects
Status Monitor