public class SoftReferenceEntryCache extends EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg> implements org.forgerock.opendj.config.server.ConfigurationChangeListener<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>, Runnable
cacheHits, cacheMisses| Constructor and Description |
|---|
SoftReferenceEntryCache()
Creates a new instance of this soft reference entry cache.
|
| Modifier and Type | Method and Description |
|---|---|
org.forgerock.opendj.config.server.ConfigChangeResult |
applyConfigurationChange(org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg configuration) |
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.
|
boolean |
containsEntry(org.forgerock.opendj.ldap.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.
|
Entry |
getEntry(org.forgerock.opendj.ldap.DN entryDN)
Retrieves the entry with the specified DN from the cache.
|
org.forgerock.opendj.ldap.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(org.forgerock.opendj.ldap.DN entryDN)
Retrieves the entry ID for the entry with the specified DN from
the cache.
|
MonitorData |
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(ServerContext serverContext,
org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg configuration)
Initializes this entry cache implementation so that it will be
available for storing and retrieving entries.
|
boolean |
isConfigurationAcceptable(org.forgerock.opendj.server.config.server.EntryCacheCfg configuration,
List<org.forgerock.i18n.LocalizableMessage> unacceptableReasons)
Indicates whether the provided configuration is acceptable for
this entry cache.
|
boolean |
isConfigurationChangeAcceptable(org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg configuration,
List<org.forgerock.i18n.LocalizableMessage> unacceptableReasons) |
boolean |
processEntryCacheConfig(org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg configuration,
boolean applyChanges,
EntryCacheCommon.ConfigErrorHandler errorHandler)
Parses the provided configuration and configure the entry cache.
|
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(org.forgerock.opendj.ldap.DN entryDN)
Removes the specified entry from the cache.
|
void |
run()
Operate in a loop, receiving notification of soft references that have been
freed and removing the corresponding entries from the cache.
|
String |
toVerboseString()
Return a verbose string representation of the current cache maps.
|
filtersAllowCaching, getCacheHits, getCacheMisses, getEntry, getEntryCacheMonitor, getExcludeFilters, getIncludeFilters, setEntryCacheMonitor, setExcludeFilters, setIncludeFilterspublic SoftReferenceEntryCache()
initializeEntryCache
method.public void initializeEntryCache(ServerContext serverContext, org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg configuration) throws org.forgerock.opendj.config.server.ConfigException, InitializationException
EntryCacheinitializeEntryCache in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>serverContext - The server context.configuration - 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()
EntryCachefinalizeEntryCache in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>public boolean containsEntry(org.forgerock.opendj.ldap.DN entryDN)
EntryCachecontainsEntry in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>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(org.forgerock.opendj.ldap.DN entryDN)
EntryCachegetEntry in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>entryDN - The DN of the entry to retrieve.null if it is not present.public long getEntryID(org.forgerock.opendj.ldap.DN entryDN)
EntryCachegetEntryID in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>entryDN - The DN of the entry for which to retrieve the
entry ID.public org.forgerock.opendj.ldap.DN getEntryDN(String backendID, long entryID)
EntryCachegetEntryDN in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>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)
EntryCacheputEntry in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>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)
EntryCacheputEntryIfAbsent in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>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(org.forgerock.opendj.ldap.DN entryDN)
EntryCacheremoveEntry in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>entryDN - The DN of the entry to remove from the cache.public void clear()
EntryCacheclear in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>public void clearBackend(String backendID)
EntryCacheclearBackend in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>backendID - ID of the backend for which to flush the
associated entries.public void handleLowMemory()
EntryCachehandleLowMemory in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>public boolean isConfigurationAcceptable(org.forgerock.opendj.server.config.server.EntryCacheCfg configuration,
List<org.forgerock.i18n.LocalizableMessage> unacceptableReasons)
EntryCacheisConfigurationAcceptable in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>configuration - The entry cache configuration for
which to make the determination.unacceptableReasons - A list that may be used to hold the
reasons that the provided
configuration is not acceptable.true if the provided configuration is acceptable
for this entry cache, or false if not.public boolean isConfigurationChangeAcceptable(org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg configuration,
List<org.forgerock.i18n.LocalizableMessage> unacceptableReasons)
isConfigurationChangeAcceptable in interface org.forgerock.opendj.config.server.ConfigurationChangeListener<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>public org.forgerock.opendj.config.server.ConfigChangeResult applyConfigurationChange(org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg configuration)
applyConfigurationChange in interface org.forgerock.opendj.config.server.ConfigurationChangeListener<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>public boolean processEntryCacheConfig(org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg configuration,
boolean applyChanges,
EntryCacheCommon.ConfigErrorHandler errorHandler)
configuration - The new configuration containing the changes.applyChanges - If true then take into account the new configuration.errorHandler - An handler used to report errors.true if configuration is acceptable,
or false otherwise.public void run()
public MonitorData getMonitorData()
EntryCachegetMonitorData in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>public Long getCacheCount()
EntryCachegetCacheCount in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>public String toVerboseString()
EntryCacheThis method is invoked by unit tests for debugging.
toVerboseString in class EntryCache<org.forgerock.opendj.server.config.server.SoftReferenceEntryCacheCfg>null if all maps are empty.Copyright © 2010-2020 Wren Security. All Rights Reserved.