@ThreadSafe public class RestStore extends Object implements AdvancedLoadWriteStore
AdvancedCacheLoader.CacheLoaderTask<K,V>, AdvancedCacheLoader.TaskContextAdvancedCacheWriter.PurgeListener<K>| Constructor and Description |
|---|
RestStore() |
| Modifier and Type | Method and Description |
|---|---|
void |
clear()
Removes all the data from the storage.
|
boolean |
contains(Object o)
Returns true if the storage contains an entry associated with the given key.
|
boolean |
delete(Object key) |
void |
init(InitializationContext initializationContext)
Used to initialize a cache loader.
|
MarshalledEntry |
load(Object key)
Fetches an entry from the storage.
|
void |
process(KeyFilter keyFilter,
AdvancedCacheLoader.CacheLoaderTask cacheLoaderTask,
Executor executor,
boolean loadValue,
boolean loadMetadata)
Iterates in parallel over the entries in the storage using the threads from the executor pool.
|
void |
purge(Executor executor,
AdvancedCacheWriter.PurgeListener purgeListener)
Using the thread in the pool, removed all the expired data from the persistence storage.
|
void |
setInternalCacheEntryFactory(InternalEntryFactory iceFactory) |
int |
size()
Returns the number of elements in the store.
|
void |
start()
Invoked on component start
|
void |
stop()
Invoked on component stop
|
void |
write(MarshalledEntry entry)
Persists the entry to the storage.
|
public void init(InitializationContext initializationContext)
CacheLoaderPersistenceManager
when setting up cache loaders.init in interface CacheLoaderinit in interface CacheWriterpublic void start()
Lifecyclepublic void stop()
Lifecyclepublic void setInternalCacheEntryFactory(InternalEntryFactory iceFactory)
public void write(MarshalledEntry entry)
CacheWriterwrite in interface CacheWriterMarshalledEntrypublic void clear()
AdvancedCacheWriterclear in interface AdvancedCacheWriterpublic boolean delete(Object key)
delete in interface CacheWriterpublic MarshalledEntry load(Object key)
CacheLoaderMarshalledEntry needs to be created here, InitializationContext.getMarshalledEntryFactory() and InitializationContext.getByteBufferFactory() should be used.load in interface CacheLoaderpublic void process(KeyFilter keyFilter, AdvancedCacheLoader.CacheLoaderTask cacheLoaderTask, Executor executor, boolean loadValue, boolean loadMetadata)
AdvancedCacheLoaderCacheLoaderTask#processEntry(MarshalledEntry, TaskContext) is
invoked. Before passing an entry to the callback task, the entry should be validated against the filter.
Implementors should build an AdvancedCacheLoader.TaskContext instance (implementation) that is fed to the AdvancedCacheLoader.CacheLoaderTask on every invocation. The AdvancedCacheLoader.CacheLoaderTask might invoke AdvancedCacheLoader.TaskContext.stop() at any time, so implementors of this method
should verify TaskContext's state for early termination of iteration. The method should only return once the
iteration is complete or as soon as possible in the case TaskContext.stop() is invoked.process in interface AdvancedCacheLoaderkeyFilter - to validate which entries should be feed into the task. Might be null.cacheLoaderTask - callback to be invoked in parallel for each stored entry that passes the filter checkexecutor - an external thread pool to be used for parallel iterationloadValue - whether or not to fetch the value from the persistent store. E.g. if the iteration is
intended only over the key set, no point fetching the values from the persistent store as
wellloadMetadata - whether or not to fetch the metadata from the persistent store. E.g. if the iteration is
intended only ove the key set, then no pint fetching the metadata from the persistent store
as wellpublic void purge(Executor executor, AdvancedCacheWriter.PurgeListener purgeListener)
AdvancedCacheWriterpurge in interface AdvancedCacheWriterpublic int size()
AdvancedCacheLoadersize in interface AdvancedCacheLoaderpublic boolean contains(Object o)
CacheLoadercontains in interface CacheLoaderCopyright © 2017 JBoss, a division of Red Hat. All rights reserved.