Я пытаюсь настроить (J) кеши в сочетании декларативной и императивной конфигурации, поскольку стандарт JCache не предоставляет средств для ограничения максимального размера кеша, который может занимать. Я хочу сделать это как можно более независимым от провайдера, чтобы в будущем у меня была возможность сменить провайдера. В настоящее время у меня есть ограничение на использование Java 7, поэтому я считаю, что Caffeine отбрасывается.
Я храню список кешей и продолжительность (TTL) их записей в моем application.yaml, который я получаю с помощью загрузчика свойств. Затем я создаю свои кэши с помощью кода ниже:
@Bean
public List<Cache<Object, Object>> getCaches() {
CacheManager cacheManager = this.getCacheManager();
List<Cache<Object, Object>> caches = new ArrayList();
Map<String, String> cacheconfigs = this.cacheConfigPropertyLoader.getPropertyLoader().getCacheconfigs();
Set<String> keySet = cacheconfigs.keySet();
Iterator i$ = keySet.iterator();
while(i$.hasNext()) {
String name = (String)i$.next();
String durationMinutes = (String)cacheconfigs.get(name);
caches.add((new GenericDefaultCacheConfigurator.GenericDefaultCacheConfig(name, new Duration(TimeUnit.MINUTES, Long.valueOf(durationMinutes)))).getCache(cacheManager));
}
return caches;
}
@Bean
public CacheManager getCacheManager() {
return Caching.getCachingProvider().getCacheManager();
}
private class GenericDefaultCacheConfig {
public GenericDefaultCacheConfig(String cacheName, Duration duration) {
public GenericDefaultCacheConfig(String id, Duration duration, Factory expiryPolicyFactory) {
CACHE_ID = id;
DURATION = duration;
EXPIRY_POLICY = expiryPolicyFactory;
}
private MutableConfiguration<Object, Object> getCacheConfiguration() {
return new MutableConfiguration<Object, Object>()
.setTypes(Object.class, Object.class)
.setStoreByValue(true)
.setExpiryPolicyFactory(EXPIRY_POLICY);
}
public Cache<Object, Object> getCache(CacheManager cacheManager) {
CacheManager cm = cacheManager;
Cache<K, V> cache = cm.getCache(CACHE_ID, Object.class, Object.class);
if (cache == null)
cache = cm.createCache(CACHE_ID, getCacheConfiguration());
return cache;
}
}
Это прекрасно работает для создания моих кешей и использования их с аннотациями и императивным кодом, независимо от того, какой поставщик JCache я использую в POM (я тестировал его с org.jsr107.ri, hazelcast и EhCache).
Теперь мне нужно ограничить максимальный размер всех кешей с помощью собственной конфигурации. Мне нужна общая конфигурация/конфигурация по умолчанию, которая применялась бы к любому кешу, созданному этим провайдером, независимо от их других конкретных характеристик (политика истечения срока действия, время жизни и т. д.), которые задаются императивной конфигурацией.
У меня возникли проблемы при включении файла конфигурации для менеджера кеша, настроенного с помощью файла конфигурации, который будет использоваться для создания этих кешей, объявленных в моем файле yaml. Есть идеи/предложения? Я помню, что где-то читал об использовании * в конфигурации Ehcache, но не смог снова найти эту страницу.