From f061e44af7b53a1eb989405fac9d36a193bd76f0 Mon Sep 17 00:00:00 2001 From: Gabriel Roldan Date: Sun, 28 Jan 2024 21:19:42 -0300 Subject: [PATCH] Validate cache availability before creating caching catalog and config facades --- config | 2 +- .../RemoteEventResourcePoolProcessor.java | 8 ++++++-- .../cache/CachingCatalogFacadeImpl.java | 5 ++--- .../cache/CachingGeoServerFacadeImpl.java | 7 +++---- .../GeoServerBackendCacheConfiguration.java | 18 ++++++++++++++++-- .../cloud/catalog/cache/ServiceInfoKey.java | 9 +++------ .../remote/cache/RemoteEventCacheEvictor.java | 2 +- .../cache/RemoteEventCacheEvictorTest.java | 2 +- ...moteEventCacheEvictorTestConfiguration.java | 10 +++++----- 9 files changed, 38 insertions(+), 25 deletions(-) diff --git a/config b/config index f58f551cb..80fe78359 160000 --- a/config +++ b/config @@ -1 +1 @@ -Subproject commit f58f551cbe4119e785ec9e66b614015668f72f12 +Subproject commit 80fe7835999b352297e250c9e8455825ba074332 diff --git a/src/catalog/backends/common/src/main/java/org/geoserver/cloud/event/remote/resourcepool/RemoteEventResourcePoolProcessor.java b/src/catalog/backends/common/src/main/java/org/geoserver/cloud/event/remote/resourcepool/RemoteEventResourcePoolProcessor.java index 13c5620d8..190d816e8 100644 --- a/src/catalog/backends/common/src/main/java/org/geoserver/cloud/event/remote/resourcepool/RemoteEventResourcePoolProcessor.java +++ b/src/catalog/backends/common/src/main/java/org/geoserver/cloud/event/remote/resourcepool/RemoteEventResourcePoolProcessor.java @@ -86,13 +86,17 @@ private void evictFromResourcePool(InfoEvent event) { info.ifPresentOrElse( object -> { - log.debug("Evict cache entry for {}({}) upon {}", infoType, id, event); + log.info( + "Evicting ResourcePool cache entry for {}({}) upon {}", + infoType, + id, + event); ResourcePool resourcePool = rawCatalog.getResourcePool(); CacheClearingListener cleaner = new CacheClearingListener(resourcePool); object.accept(cleaner); }, // () -> - log.info( + log.debug( "{}({}) not found, unable to clean up its ResourcePool cache entry", infoType, id)); diff --git a/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/CachingCatalogFacadeImpl.java b/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/CachingCatalogFacadeImpl.java index 1c433d1f9..5ef1fefa9 100644 --- a/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/CachingCatalogFacadeImpl.java +++ b/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/CachingCatalogFacadeImpl.java @@ -22,7 +22,6 @@ import org.geoserver.catalog.plugin.forwarding.ForwardingExtendedCatalogFacade; import org.springframework.cache.Cache; import org.springframework.cache.Cache.ValueWrapper; -import org.springframework.cache.CacheManager; import org.springframework.cache.annotation.CacheConfig; import org.springframework.cache.annotation.CacheEvict; import org.springframework.cache.annotation.CachePut; @@ -38,9 +37,9 @@ class CachingCatalogFacadeImpl extends ForwardingExtendedCatalogFacade implements CachingCatalogFacade { private Cache idCache; - public CachingCatalogFacadeImpl(ExtendedCatalogFacade facade, CacheManager cacheManager) { + public CachingCatalogFacadeImpl(@NonNull ExtendedCatalogFacade facade, @NonNull Cache cache) { super(facade); - idCache = cacheManager.getCache(CachingCatalogFacade.CACHE_NAME); + this.idCache = cache; } @Override diff --git a/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/CachingGeoServerFacadeImpl.java b/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/CachingGeoServerFacadeImpl.java index 33ad58c4f..9bd046bd9 100644 --- a/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/CachingGeoServerFacadeImpl.java +++ b/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/CachingGeoServerFacadeImpl.java @@ -17,7 +17,6 @@ import org.geoserver.config.plugin.forwarding.ForwardingGeoServerFacade; import org.springframework.cache.Cache; import org.springframework.cache.Cache.ValueWrapper; -import org.springframework.cache.CacheManager; import org.springframework.cache.annotation.CacheConfig; import org.springframework.cache.annotation.CacheEvict; import org.springframework.cache.annotation.Cacheable; @@ -31,7 +30,7 @@ class CachingGeoServerFacadeImpl extends ForwardingGeoServerFacade implements CachingGeoServerFacade { - private Cache cache; + private final @NonNull Cache cache; @Override public Optional evictGlobal() { @@ -109,9 +108,9 @@ static T cachePut(@NonNull Cache cache, @NonNull T servi return service; } - public CachingGeoServerFacadeImpl(GeoServerFacade facade, CacheManager cacheManager) { + public CachingGeoServerFacadeImpl(@NonNull GeoServerFacade facade, @NonNull Cache cache) { super(facade); - cache = cacheManager.getCache(CACHE_NAME); + this.cache = cache; } @Cacheable(key = "'" + GEOSERVERINFO_KEY + "'", unless = "#result == null") diff --git a/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/GeoServerBackendCacheConfiguration.java b/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/GeoServerBackendCacheConfiguration.java index 608e5f971..61c333be0 100644 --- a/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/GeoServerBackendCacheConfiguration.java +++ b/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/GeoServerBackendCacheConfiguration.java @@ -12,11 +12,14 @@ import org.geoserver.config.GeoServerFacade; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.beans.factory.config.BeanPostProcessor; +import org.springframework.cache.Cache; import org.springframework.cache.CacheManager; import org.springframework.cache.annotation.EnableCaching; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; +import java.util.Objects; + /** * Enables caching at the {@link CatalogFacade} and {@link GeoServerFacade} level instead of at the * {@link Catalog} and {@link GeoServer} level, which would be the natural choice, in order not to @@ -47,13 +50,24 @@ CachingCatalogFacade cachingCatalogFacade( } else { facade = new CatalogFacadeExtensionAdapter(rawCatalogFacade); } - return new CachingCatalogFacadeImpl(facade, cacheManager); + Cache cache = getCache(cacheManager, CachingCatalogFacade.CACHE_NAME); + return new CachingCatalogFacadeImpl(facade, cache); } @Bean CachingGeoServerFacade cachingGeoServerFacade( @Qualifier("geoserverFacade") GeoServerFacade rawGeoServerFacade, CacheManager cacheManager) { - return new CachingGeoServerFacadeImpl(rawGeoServerFacade, cacheManager); + Cache cache = getCache(cacheManager, CachingGeoServerFacade.CACHE_NAME); + return new CachingGeoServerFacadeImpl(rawGeoServerFacade, cache); + } + + private Cache getCache(CacheManager cacheManager, String cacheName) { + Cache cache = cacheManager.getCache(cacheName); + Objects.requireNonNull( + cache, + "CacheManager %s returned null cache for cache name %s" + .formatted(cacheManager.getClass().getName(), cacheName)); + return cache; } } diff --git a/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/ServiceInfoKey.java b/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/ServiceInfoKey.java index 654e63232..d2086aa1a 100644 --- a/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/ServiceInfoKey.java +++ b/src/catalog/cache/src/main/java/org/geoserver/cloud/catalog/cache/ServiceInfoKey.java @@ -4,16 +4,13 @@ */ package org.geoserver.cloud.catalog.cache; -import lombok.Value; - import org.geoserver.catalog.WorkspaceInfo; import org.geoserver.config.ServiceInfo; +import java.io.Serializable; + /** */ -@Value -class ServiceInfoKey { - private String firstIdentifier; - private String secondIdentifier; +record ServiceInfoKey(String key, String qualifier) implements Serializable { public static ServiceInfoKey byId(String id) { return new ServiceInfoKey(id, null); diff --git a/src/catalog/cache/src/main/java/org/geoserver/cloud/event/remote/cache/RemoteEventCacheEvictor.java b/src/catalog/cache/src/main/java/org/geoserver/cloud/event/remote/cache/RemoteEventCacheEvictor.java index 6ac319c57..fad042133 100644 --- a/src/catalog/cache/src/main/java/org/geoserver/cloud/event/remote/cache/RemoteEventCacheEvictor.java +++ b/src/catalog/cache/src/main/java/org/geoserver/cloud/event/remote/cache/RemoteEventCacheEvictor.java @@ -179,7 +179,7 @@ private void evictEntry(InfoEvent event, BooleanSupplier evictor) { evt -> { boolean evicted = evictor.getAsBoolean(); if (evicted) { - log.debug("Evicted cache entry {}", evt); + log.debug("Evicted Catalog cache entry due to {}", evt); } else { log.trace("Remote event resulted in no cache eviction: {}", evt); } diff --git a/src/catalog/cache/src/test/java/org/geoserver/cloud/event/remote/cache/RemoteEventCacheEvictorTest.java b/src/catalog/cache/src/test/java/org/geoserver/cloud/event/remote/cache/RemoteEventCacheEvictorTest.java index 512b3c9f4..cda56a2b9 100644 --- a/src/catalog/cache/src/test/java/org/geoserver/cloud/event/remote/cache/RemoteEventCacheEvictorTest.java +++ b/src/catalog/cache/src/test/java/org/geoserver/cloud/event/remote/cache/RemoteEventCacheEvictorTest.java @@ -93,7 +93,7 @@ class RemoteEventCacheEvictorTest { * Spring-cache for configuration Info objects, named after {@link * CachingGeoServerFacade#CACHE_NAME} */ - private Cache configCache; + private org.springframework.cache.Cache configCache; private @Autowired @Qualifier("catalog") Catalog catalog; private @Autowired @Qualifier("geoServer") GeoServerImpl geoServer; diff --git a/src/catalog/cache/src/test/java/org/geoserver/cloud/event/remote/cache/RemoteEventCacheEvictorTestConfiguration.java b/src/catalog/cache/src/test/java/org/geoserver/cloud/event/remote/cache/RemoteEventCacheEvictorTestConfiguration.java index 3e3b2de6b..ef67dc24e 100644 --- a/src/catalog/cache/src/test/java/org/geoserver/cloud/event/remote/cache/RemoteEventCacheEvictorTestConfiguration.java +++ b/src/catalog/cache/src/test/java/org/geoserver/cloud/event/remote/cache/RemoteEventCacheEvictorTestConfiguration.java @@ -39,17 +39,17 @@ UpdateSequence defaultUpdateSequence(GeoServer geoserver) { } @Bean(name = {"rawCatalog"}) - public Catalog rawCatalog(@Qualifier("catalogFacade") CatalogFacade facade) { + Catalog rawCatalog(@Qualifier("catalogFacade") CatalogFacade facade) { return new CatalogPlugin(facade); } @Bean(name = {"catalog"}) - public Catalog catalog(@Qualifier("rawCatalog") Catalog raw) { + Catalog catalog(@Qualifier("rawCatalog") Catalog raw) { return raw; } @Bean(name = "geoServer") - public GeoServer geoServer( + GeoServer geoServer( @Qualifier("catalog") Catalog catalog, @Qualifier("geoserverFacade") GeoServerFacade facade) { @@ -59,12 +59,12 @@ public GeoServer geoServer( } @Bean(name = "catalogFacade") - public CatalogFacade catalogFacade() { + CatalogFacade catalogFacade() { return new DefaultMemoryCatalogFacade(); } @Bean(name = "geoserverFacade") - public GeoServerFacade geoserverFacade() { + GeoServerFacade geoserverFacade() { return new RepositoryGeoServerFacadeImpl(); } }