org.infinispan.eviction.impl.ActivationManagerImpl Maven / Gradle / Ivy
package org.infinispan.eviction.impl;
import org.infinispan.commons.CacheException;
import org.infinispan.configuration.cache.Configuration;
import org.infinispan.eviction.ActivationManager;
import org.infinispan.factories.annotations.Inject;
import org.infinispan.factories.annotations.Start;
import org.infinispan.interceptors.locking.ClusteringDependentLogic;
import org.infinispan.jmx.annotations.MBean;
import org.infinispan.jmx.annotations.ManagedAttribute;
import org.infinispan.jmx.annotations.ManagedOperation;
import org.infinispan.jmx.annotations.MeasurementType;
import org.infinispan.persistence.manager.PersistenceManager;
import org.infinispan.util.logging.Log;
import org.infinispan.util.logging.LogFactory;
import java.util.concurrent.atomic.AtomicLong;
import static org.infinispan.persistence.manager.PersistenceManager.AccessMode;
import static org.infinispan.persistence.manager.PersistenceManager.AccessMode.BOTH;
import static org.infinispan.persistence.manager.PersistenceManager.AccessMode.PRIVATE;
import static org.infinispan.persistence.manager.PersistenceManager.AccessMode.SHARED;
/**
* Concrete implementation of activation logic manager.
*
* @author Galder Zamarreño
* @since 5.2
*/
@MBean(objectName = "Activation",
description = "Component that handles activating entries that have been passivated to a CacheStore by loading them into memory.")
public class ActivationManagerImpl implements ActivationManager {
private static final Log log = LogFactory.getLog(ActivationManagerImpl.class);
private final AtomicLong activations = new AtomicLong(0);
private PersistenceManager persistenceManager;
private Configuration cfg;
private ClusteringDependentLogic clusteringDependentLogic;
private boolean passivation;
@ManagedAttribute(description = "Enables or disables the gathering of statistics by this component", displayName = "Statistics enabled", writable = true)
private boolean statisticsEnabled = false;
@Inject
public void inject(PersistenceManager clm, Configuration cfg, ClusteringDependentLogic cdl) {
this.persistenceManager = clm;
this.cfg = cfg;
this.clusteringDependentLogic = cdl;
}
@Start(priority = 11) // After the cache loader manager, before the passivation manager
public void start() {
statisticsEnabled = cfg.jmxStatistics().enabled();
passivation = cfg.persistence().passivation();
}
@Override
public void onUpdate(Object key, boolean newEntry) {
if (!passivation || !newEntry) {
//we don't have passivation or the entry already exists in container.
return;
}
try {
if (persistenceManager.deleteFromAllStores(key, PRIVATE) && statisticsEnabled) {
activations.incrementAndGet();
}
} catch (CacheException e) {
log.unableToRemoveEntryAfterActivation(key, e);
}
}
@Override
public void onRemove(Object key, boolean newEntry) {
if (!passivation) {
return;
}
//if we are the primary owner, we need to remove from the shared store,
final boolean primaryOwner = clusteringDependentLogic.localNodeIsPrimaryOwner(key);
try {
if (newEntry) {
//the entry does not exists in data container. We need to remove from private and shared stores.
//if we are the primary owner
AccessMode mode = primaryOwner ? BOTH : PRIVATE;
if (persistenceManager.deleteFromAllStores(key, mode) && statisticsEnabled) {
activations.incrementAndGet();
}
} else {
//the entry already exists in data container. It may be put during the load by the CacheLoaderInterceptor
//so it was already activate in the private stores.
if (primaryOwner && persistenceManager.deleteFromAllStores(key, SHARED) && statisticsEnabled) {
activations.incrementAndGet();
}
}
} catch (CacheException e) {
log.unableToRemoveEntryAfterActivation(key, e);
}
}
@Override
public long getActivationCount() {
return activations.get();
}
@ManagedAttribute(
description = "Number of activation events",
displayName = "Number of cache entries activated",
measurementType = MeasurementType.TRENDSUP
)
public String getActivations() {
if (!statisticsEnabled)
return "N/A";
return String.valueOf(getActivationCount());
}
@ManagedOperation(
description = "Resets statistics gathered by this component",
displayName = "Reset statistics"
)
public void resetStatistics() {
activations.set(0);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy