Package org.infinispan.persistence.spi
Interface AdvancedCacheWriter<K,V>
-
- All Superinterfaces:
CacheWriter<K,V>
,Lifecycle
- All Known Subinterfaces:
AdvancedCacheExpirationWriter<K,V>
,AdvancedLoadWriteStore<K,V>
,SegmentedAdvancedLoadWriteStore<K,V>
,TransactionalCacheWriter<K,V>
- All Known Implementing Classes:
AbstractSegmentedAdvancedLoadWriteStore
,AdvancedAsyncCacheWriter
,AdvancedSingletonCacheWriter
,ComposedSegmentedLoadWriteStore
,JdbcStringBasedStore
,JpaStore
,LevelDBStore
,RemoteStore
,RestStore
,org.infinispan.persistence.rocksdb.RocksDBStore
,SingleFileStore
@ThreadSafe public interface AdvancedCacheWriter<K,V> extends CacheWriter<K,V>
Defines advanced functionality for persisting data to an external storage.- Since:
- 6.0
- Author:
- Mircea Markus
-
-
Nested Class Summary
Nested Classes Modifier and Type Interface Description static interface
AdvancedCacheWriter.PurgeListener<K>
Callback to be notified when an entry is removed by thepurge(java.util.concurrent.Executor, org.infinispan.persistence.spi.AdvancedCacheWriter.PurgeListener)
method.
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description void
clear()
Removes all the data from the storage.void
purge(Executor threadPool, AdvancedCacheWriter.PurgeListener<? super K> listener)
Using the thread in the pool, removed all the expired data from the persistence storage.-
Methods inherited from interface org.infinispan.persistence.spi.CacheWriter
delete, deleteBatch, init, isAvailable, write, writeBatch
-
-
-
-
Method Detail
-
clear
void clear()
Removes all the data from the storage.- Throws:
PersistenceException
- in case of an error, e.g. communicating with the external storage
-
purge
void purge(Executor threadPool, AdvancedCacheWriter.PurgeListener<? super K> listener)
Using the thread in the pool, removed all the expired data from the persistence storage. For each removed entry, the supplied listener is invoked.When this method returns all entries will be purged and no tasks will be running due to this loader in the provided executor. If however an exception is thrown there could be tasks still pending or running in the executor.
- Throws:
PersistenceException
- in case of an error, e.g. communicating with the external storage
-
-