public class LevelDBStore extends Object implements AdvancedLoadWriteStore
AdvancedCacheLoader.CacheLoaderTask<K,V>, AdvancedCacheLoader.KeyFilter<K>, AdvancedCacheLoader.TaskContext
AdvancedCacheWriter.PurgeListener<K>
Constructor and Description |
---|
LevelDBStore() |
Modifier and Type | Method and Description |
---|---|
void |
clear()
Removes all the data from the storage.
|
boolean |
contains(Object key)
Returns true if the storage contains an entry associated with the given key.
|
boolean |
delete(Object key) |
protected void |
destroyDatabase(String location) |
void |
init(InitializationContext ctx)
Used to initialize a cache loader.
|
MarshalledEntry |
load(Object key)
Fetches an entry from the storage.
|
protected org.iq80.leveldb.DBFactory |
newDbFactory() |
protected org.iq80.leveldb.DB |
openDatabase(String location,
org.iq80.leveldb.Options options)
Creates database if it doesn't exist.
|
void |
process(AdvancedCacheLoader.KeyFilter keyFilter,
AdvancedCacheLoader.CacheLoaderTask cacheLoaderTask,
Executor executor,
boolean loadValues,
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.
|
protected void |
reinitAllDatabases() |
protected org.iq80.leveldb.DB |
reinitDatabase(String location,
org.iq80.leveldb.Options options) |
int |
size()
Returns the number of elements in the store.
|
void |
start() |
void |
stop() |
void |
write(MarshalledEntry me)
Persists the entry to the storage.
|
public void init(InitializationContext ctx)
CacheLoader
PersistenceManager
when setting up cache loaders.init
in interface CacheLoader
init
in interface CacheWriter
protected org.iq80.leveldb.DBFactory newDbFactory()
protected org.iq80.leveldb.DB openDatabase(String location, org.iq80.leveldb.Options options) throws IOException
IOException
protected void destroyDatabase(String location) throws IOException
IOException
protected org.iq80.leveldb.DB reinitDatabase(String location, org.iq80.leveldb.Options options) throws IOException
IOException
protected void reinitAllDatabases() throws IOException
IOException
public void clear()
AdvancedCacheWriter
clear
in interface AdvancedCacheWriter
public int size()
AdvancedCacheLoader
size
in interface AdvancedCacheLoader
public boolean contains(Object key)
CacheLoader
contains
in interface CacheLoader
public void process(AdvancedCacheLoader.KeyFilter keyFilter, AdvancedCacheLoader.CacheLoaderTask cacheLoaderTask, Executor executor, boolean loadValues, boolean loadMetadata)
AdvancedCacheLoader
CacheLoaderTask#processEntry(org.infinispan.marshall.core.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 AdvancedCacheLoader
keyFilter
- 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 iterationloadValues
- 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 boolean delete(Object key)
delete
in interface CacheWriter
public void write(MarshalledEntry me)
CacheWriter
write
in interface CacheWriter
MarshalledEntry
public MarshalledEntry load(Object key)
CacheLoader
MarshalledEntry
needs to be created here, InitializationContext.getMarshalledEntryFactory()
and InitializationContext.getByteBufferFactory()
should be used.load
in interface CacheLoader
public void purge(Executor executor, AdvancedCacheWriter.PurgeListener purgeListener)
AdvancedCacheWriter
purge
in interface AdvancedCacheWriter
Copyright © 2014 JBoss, a division of Red Hat. All Rights Reserved.