org.infinispan.configuration.cache.EvictionConfigurationBuilder Maven / Gradle / Ivy
package org.infinispan.configuration.cache;
import org.infinispan.commons.configuration.Builder;
import org.infinispan.commons.CacheConfigurationException;
import org.infinispan.configuration.global.GlobalConfiguration;
import org.infinispan.eviction.EvictionStrategy;
import org.infinispan.eviction.EvictionThreadPolicy;
import org.infinispan.util.logging.Log;
import org.infinispan.util.logging.LogFactory;
/**
* Controls the eviction settings for the cache.
*/
public class EvictionConfigurationBuilder extends AbstractConfigurationChildBuilder implements Builder {
private static final Log log = LogFactory.getLog(EvictionConfigurationBuilder.class);
private int maxEntries = -1;
private EvictionStrategy strategy = EvictionStrategy.NONE;
private EvictionThreadPolicy threadPolicy = EvictionThreadPolicy.DEFAULT;
EvictionConfigurationBuilder(ConfigurationBuilder builder) {
super(builder);
}
/**
* Eviction strategy. Available options are 'UNORDERED', 'LRU', 'LIRS' and 'NONE' (to disable
* eviction).
*
* @param evictionStrategy
*/
public EvictionConfigurationBuilder strategy(EvictionStrategy evictionStrategy) {
this.strategy = evictionStrategy;
return this;
}
EvictionStrategy strategy() {
return strategy;
}
/**
* Threading policy for eviction.
*
* @param policy
*/
public EvictionConfigurationBuilder threadPolicy(EvictionThreadPolicy policy) {
this.threadPolicy = policy;
return this;
}
/**
* Maximum number of entries in a cache instance. Cache size is guaranteed not to exceed upper
* limit specified by max entries. However, due to the nature of eviction it is unlikely to ever
* be exactly maximum number of entries specified here.
*
* @param maxEntries
*/
public EvictionConfigurationBuilder maxEntries(int maxEntries) {
this.maxEntries = maxEntries;
return this;
}
@Override
public void validate() {
if (!strategy.isEnabled() && getBuilder().persistence().passivation())
log.passivationWithoutEviction();
if(strategy == EvictionStrategy.FIFO)
log.warnFifoStrategyIsDeprecated();
if (strategy.isEnabled() && maxEntries <= 0)
throw new CacheConfigurationException("Eviction maxEntries value cannot be less than or equal to zero if eviction is enabled");
if (maxEntries > 0 && !strategy.isEnabled()) {
strategy = EvictionStrategy.LIRS;
log.debugf("Max entries configured (%d) without eviction strategy. Eviction strategy overriden to %s", maxEntries, strategy);
}
}
@Override
public void validate(GlobalConfiguration globalConfig) {
}
@Override
public EvictionConfiguration create() {
return new EvictionConfiguration(maxEntries, strategy, threadPolicy);
}
@Override
public EvictionConfigurationBuilder read(EvictionConfiguration template) {
this.maxEntries = template.maxEntries();
this.strategy = template.strategy();
this.threadPolicy = template.threadPolicy();
return this;
}
@Override
public String toString() {
return "EvictionConfigurationBuilder{" +
"maxEntries=" + maxEntries +
", strategy=" + strategy +
", threadPolicy=" + threadPolicy +
'}';
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy