public class DefaultEntryCache extends EntryCache<EntryCacheCfg> implements ConfigurationChangeListener<EntryCacheCfg>, BackendInitializationListener
cacheHits, cacheMisses
Constructor and Description |
---|
DefaultEntryCache()
Creates a new instance of this default entry cache.
|
Modifier and Type | Method and Description |
---|---|
org.forgerock.opendj.config.server.ConfigChangeResult |
applyConfigurationChange(EntryCacheCfg configuration)
Applies the configuration changes to this change listener.
|
void |
clear()
Removes all entries from the cache.
|
void |
clearBackend(String backendID)
Removes all entries from the cache that are associated with the
provided backend.
|
void |
clearSubtree(DN baseDN)
Removes all entries from the cache that are below the provided
DN.
|
boolean |
containsEntry(DN entryDN)
Indicates whether the entry cache currently contains the entry
with the specified DN.
|
void |
finalizeEntryCache()
Performs any necessary cleanup work (e.g., flushing all cached
entries and releasing any other held resources) that should be
performed when the server is to be shut down or the entry cache
destroyed or replaced.
|
Long |
getCacheCount()
Retrieves the current number of entries stored within the cache.
|
static EntryCache<? extends EntryCacheCfg>[] |
getCacheOrder()
Retrieves the current cache order array.
|
Entry |
getEntry(DN entryDN)
Retrieves the entry with the specified DN from the cache.
|
Entry |
getEntry(String backendID,
long entryID)
Retrieves the requested entry if it is present in the cache.
|
DN |
getEntryDN(String backendID,
long entryID)
Retrieves the entry DN for the entry with the specified ID on
the specific backend from the cache.
|
long |
getEntryID(DN entryDN)
Retrieves the entry ID for the entry with the specified DN from
the cache.
|
List<Attribute> |
getMonitorData()
Retrieves a set of attributes containing monitor data that should
be returned to the client if the corresponding monitor entry is
requested.
|
void |
handleLowMemory()
Attempts to react to a scenario in which it is determined that
the system is running low on available memory.
|
void |
initializeEntryCache(EntryCacheCfg configEntry)
Initializes this entry cache implementation so that it will be
available for storing and retrieving entries.
|
boolean |
isConfigurationChangeAcceptable(EntryCacheCfg configuration,
List<LocalizableMessage> unacceptableReasons)
Indicates whether the proposed change to the configuration is
acceptable to this change listener.
|
void |
performBackendPostFinalizationProcessing(Backend<?> backend)
Performs any processing that may be required whenever a backend
is finalized.
|
void |
performBackendPostInitializationProcessing(Backend<?> backend)
Performs any processing that may be required
after the Initialisation cycle has been completed, that is
all listeners have received the initialisation event, and the
backend has been put into service,.
|
void |
performBackendPreFinalizationProcessing(Backend<?> backend)
Performs any processing that may be required before starting
the finalisation cycle, that is invoked before any listener receive
the Finalization event.
|
void |
performBackendPreInitializationProcessing(Backend<?> backend)
Performs any processing that may be required whenever a backend
is initialized for use in the Directory Server.
|
void |
putEntry(Entry entry,
String backendID,
long entryID)
Stores the provided entry in the cache.
|
boolean |
putEntryIfAbsent(Entry entry,
String backendID,
long entryID)
Stores the provided entry in the cache only if it does not
conflict with an entry that already exists.
|
void |
removeEntry(DN entryDN)
Removes the specified entry from the cache.
|
static void |
setCacheOrder(SortedMap<Integer,EntryCache<? extends EntryCacheCfg>> cacheOrderMap)
Sets the current cache order array.
|
String |
toVerboseString()
Return a verbose string representation of the current cache maps.
|
filtersAllowCaching, getCacheHits, getCacheMisses, getEntryCacheMonitor, getExcludeFilters, getIncludeFilters, isConfigurationAcceptable, setEntryCacheMonitor, setExcludeFilters, setIncludeFilters
public DefaultEntryCache()
public void initializeEntryCache(EntryCacheCfg configEntry) throws org.forgerock.opendj.config.server.ConfigException, InitializationException
initializeEntryCache
in class EntryCache<EntryCacheCfg>
configEntry
- The configuration to use to initialize
the entry cache.org.forgerock.opendj.config.server.ConfigException
- If there is a problem with the provided
configuration entry that would prevent
this entry cache from being used.InitializationException
- If a problem occurs during the
initialization process that is
not related to the
configuration.public void finalizeEntryCache()
finalizeEntryCache
in class EntryCache<EntryCacheCfg>
public boolean containsEntry(DN entryDN)
containsEntry
in class EntryCache<EntryCacheCfg>
entryDN
- The DN for which to make the determination.true
if the entry cache currently contains the
entry with the specified DN, or false
if not.public Entry getEntry(String backendID, long entryID)
getEntry
in class EntryCache<EntryCacheCfg>
backendID
- ID of the backend associated with the entry
to retrieve.entryID
- The entry ID within the provided backend for
the specified entry.null
if it is not present.public Entry getEntry(DN entryDN)
getEntry
in class EntryCache<EntryCacheCfg>
entryDN
- The DN of the entry to retrieve.null
if it is not present.public long getEntryID(DN entryDN)
getEntryID
in class EntryCache<EntryCacheCfg>
entryDN
- The DN of the entry for which to retrieve the
entry ID.public DN getEntryDN(String backendID, long entryID)
getEntryDN
in class EntryCache<EntryCacheCfg>
backendID
- ID of the backend associated with the
entry for which to retrieve the entry DN.entryID
- The entry ID within the provided backend
for which to retrieve the entry DN.null
if it is not present in the cache.public void putEntry(Entry entry, String backendID, long entryID)
putEntry
in class EntryCache<EntryCacheCfg>
entry
- The entry to store in the cache.backendID
- ID of the backend with which the entry is
associated.entryID
- The entry ID within the provided backend that
uniquely identifies the specified entry.public boolean putEntryIfAbsent(Entry entry, String backendID, long entryID)
putEntryIfAbsent
in class EntryCache<EntryCacheCfg>
entry
- The entry to store in the cache.backendID
- ID of the backend with which the entry is
associated.entryID
- The entry ID within the provided backend that
uniquely identifies the specified entry.false
if an existing entry or some other problem
prevented the method from completing successfully, or
true
if there was no conflict and the entry was
either stored or the cache determined that this entry
should never be cached for some reason.public void removeEntry(DN entryDN)
removeEntry
in class EntryCache<EntryCacheCfg>
entryDN
- The DN of the entry to remove from the cache.public void clear()
clear
in class EntryCache<EntryCacheCfg>
public void clearBackend(String backendID)
clearBackend
in class EntryCache<EntryCacheCfg>
backendID
- ID of the backend for which to flush the
associated entries.public void clearSubtree(DN baseDN)
clearSubtree
in class EntryCache<EntryCacheCfg>
baseDN
- The base DN below which all entries should be
flushed.public void handleLowMemory()
handleLowMemory
in class EntryCache<EntryCacheCfg>
public boolean isConfigurationChangeAcceptable(EntryCacheCfg configuration, List<LocalizableMessage> unacceptableReasons)
isConfigurationChangeAcceptable
in interface ConfigurationChangeListener<EntryCacheCfg>
configuration
- The new configuration containing the changes.unacceptableReasons
- A list that can be used to hold messages about why the
provided configuration is not acceptable.true
if the proposed change is
acceptable, or false
if it is not.public org.forgerock.opendj.config.server.ConfigChangeResult applyConfigurationChange(EntryCacheCfg configuration)
applyConfigurationChange
in interface ConfigurationChangeListener<EntryCacheCfg>
configuration
- The new configuration containing the changes.public List<Attribute> getMonitorData()
getMonitorData
in class EntryCache<EntryCacheCfg>
public Long getCacheCount()
getCacheCount
in class EntryCache<EntryCacheCfg>
public String toVerboseString()
This method is invoked by unit tests for debugging.
toVerboseString
in class EntryCache<EntryCacheCfg>
null
if all maps are empty.public static final EntryCache<? extends EntryCacheCfg>[] getCacheOrder()
public static final void setCacheOrder(SortedMap<Integer,EntryCache<? extends EntryCacheCfg>> cacheOrderMap)
cacheOrderMap
- The current cache order array.public void performBackendPreInitializationProcessing(Backend<?> backend)
performBackendPreInitializationProcessing
in interface BackendInitializationListener
backend
- The backend that has been initialized and is
about to be put into service.public void performBackendPostFinalizationProcessing(Backend<?> backend)
performBackendPostFinalizationProcessing
in interface BackendInitializationListener
backend
- The backend that has been taken out of service
and is about to be finalized.public void performBackendPostInitializationProcessing(Backend<?> backend)
BackendInitializationListener
performBackendPostInitializationProcessing
in interface BackendInitializationListener
backend
- The backend that has been initialized and has been
put into service.public void performBackendPreFinalizationProcessing(Backend<?> backend)
BackendInitializationListener
performBackendPreFinalizationProcessing
in interface BackendInitializationListener
backend
- The backend that is about to be finalized.Copyright © 2010-2016 ForgeRock AS. All Rights Reserved.