public abstract class ListeningKernelModule extends KernelModule implements ConfChangeEventListenerI, DBManEventListenerI, FeatureListenerI, java.util.concurrent.ThreadFactory
KernelModule
subclass that listens for DBManEvents
and reacts on them.Modifier and Type | Field and Description |
---|---|
static org.apache.log4j.Logger |
log |
STR_IF_POSSIBLE, STR_MANDATORY, STR_NEVER
SAVE_RETRIES, SAVE_RETRY_DELAY_MS_MAX, SAVE_RETRY_DELAY_MS_MIN
Constructor and Description |
---|
ListeningKernelModule(java.lang.String _nameForLog,
DBManLocalI dbm) |
ListeningKernelModule(java.lang.String _nameForLog,
DBManLocalI dbm,
DBManEventFilter _eventFilter) |
ListeningKernelModule(java.lang.String _nameForLog,
DBManLocalI dbm,
DBManEventFilter _eventFilter,
java.lang.String _dependsOnFeature) |
ListeningKernelModule(java.lang.String _nameForLog,
DBManLocalI dbm,
DBManEventFilter _eventFilter,
java.lang.String _dependsOnFeature,
boolean _onlyOnAuthoritativeServer) |
Modifier and Type | Method and Description |
---|---|
int |
decrementPending() |
void |
featureBecameAvailable(java.lang.String feature)
Called when a feature just became available (that is a LicenseI was newly
imported, the starting date of its validity period arrived, or whatever).
|
void |
featureNoLongerAvailable(java.lang.String feature)
Blocks the calling
Thread until the module is fully started/active. |
java.util.concurrent.atomic.AtomicInteger |
getCPending() |
DBManEventFilter |
getEventFilter() |
java.lang.String |
getNameForLog()
Thread implementation containing the standard code to be executed for starting the module. |
int |
getPendingShowLimit() |
abstract java.lang.String |
getShouldStartSetting(DBManConfigurationHelperI conf)
Retrieves and returns if this module should actually be started from the MyTISM configuration.
|
int |
incrementPending() |
void |
initialize()
Initialization of the module; called only once during
DBMan startup. |
boolean |
isActive() |
boolean |
isMandatory()
Convenience method that tells if this module is required for this MyTISM instance, according to the configuration.
|
boolean |
isOrWillBeInactive()
Returns true if this module is either already inactive or already stopping (to become inactive).
|
boolean |
isWanted()
Convenience method that tells if this module should be started according to the configuration of this MyTISM
instance.
|
java.lang.Thread |
newThread(java.lang.Runnable r)
Creates daemon threads for the executor (boy, that really *does* sound sinister... ;-)
|
void |
processConfChangeEvent(ConfChangeEvent e)
Called when the MyTISM configuration was changed and if the setting for this module was modified either starts it
up or stops it depending on the new setting.
|
void |
processDBManEvent(DBManEvent event)
Schedules handling of the received
DBManEvent in a parallel thread. |
void |
setActive(boolean $10) |
void |
setCPending(java.util.concurrent.atomic.AtomicInteger $8) |
void |
setEventFilter(DBManEventFilter $7) |
void |
setNameForLog(java.lang.String $6) |
void |
setPendingShowLimit(int $9) |
void |
shutdown(java.util.concurrent.CountDownLatch latch,
int shutdownWaitTimeoutInSecs) |
void |
start()
Actually starts this module, if it was not already started.
|
void |
start(boolean duringStartup) |
void |
stop()
Stops/deactivates this module, if it was started/is active.
|
void |
stop(java.util.concurrent.CountDownLatch latch) |
void |
stop(java.util.concurrent.CountDownLatch latch,
int waitTimeoutInSecs) |
getBOLoader, getConfiguration, getConnection, getDbm, getJDBCConnection, getNewCachingBOLoader, getNodeNumber, getSchema, getUser, isAuthoritativeSyncServer, isShutdown, loadBO, loadBO, query, query, query, query, query, query, query, query, query, query, runsAsUser, save, save, save, save, save, save, save, save, save, save, save, save, setDbm, setShutdown, setUser, shutdown
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
handleSaveResultForRetry
wantsConnectionsClosed
public ListeningKernelModule(java.lang.String _nameForLog, DBManLocalI dbm)
_nameForLog
- FIXMEdbm
- the DBManLocalI
instance this module belongs to_eventFilter
- if a DBManEventFilter
is given (not null) the module will only react on events that
match that filter_dependsOnFeature
- FIXME_onlyOnAuthoritativeServer
- Basically if given as true it means that the module is actually started
and doing something, while if given as false it is not started and... FIXME! TT 2024-12-04: ...basically just
sits there and does nothing :-/ This flag is used by the AlarmModule only and has the effect that on sync nodes
the alarm system will do a bit of initialization work and then just hang around doing nothing at all but occupying
(a bit of) memory.public ListeningKernelModule(java.lang.String _nameForLog, DBManLocalI dbm, DBManEventFilter _eventFilter)
public ListeningKernelModule(java.lang.String _nameForLog, DBManLocalI dbm, DBManEventFilter _eventFilter, java.lang.String _dependsOnFeature)
public ListeningKernelModule(java.lang.String _nameForLog, DBManLocalI dbm, DBManEventFilter _eventFilter, java.lang.String _dependsOnFeature, boolean _onlyOnAuthoritativeServer)
public abstract java.lang.String getShouldStartSetting(DBManConfigurationHelperI conf)
public boolean isWanted()
public boolean isMandatory()
public void initialize()
DBMan
startup.
Runs synchronously, therefore care should be taken that it does not run for too long.
FIXME TT 2024-12-11: As the main work is being done in a spawned thread the above is not so relevant any more.public boolean isOrWillBeInactive()
not isActive()
or a stop thread exists; false if neither is the casepublic void processConfChangeEvent(ConfChangeEvent e)
processConfChangeEvent
in interface ConfChangeEventListenerI
e
- The ConfChangeEvent
object containing details of the configuration change.public void shutdown(java.util.concurrent.CountDownLatch latch, int shutdownWaitTimeoutInSecs)
public void featureBecameAvailable(java.lang.String feature)
FeatureListenerI
featureBecameAvailable
in interface FeatureListenerI
public void start()
Thread
.duringStartup
- if true the method was called during server startup; if false the method was called (again)
when the module was started up otherwise, for example because the required feature became availablepublic void start(boolean duringStartup)
public void featureNoLongerAvailable(java.lang.String feature)
Thread
until the module is fully started/active.
Waits at most a given number of milliseconds for the start/activation thread to die. A timeout of 0 (the default)
means to wait forever.featureNoLongerAvailable
in interface FeatureListenerI
delayInMS
- the given number of milliseconds to wait for the start/activation thread to die. A timeout of 0
(the default) means to wait foreverpublic void stop()
Thread
that performs the
actual stopping asynchronously.latch
- a CountDownLatch
which is provided and used by the DBMan
in case of server shutdown
to monitor module shutdown; if null (the default) it means this method was not called during shutdownwaitTimeoutInSecs
- time in seconds the DBMan
will wait at most for this module to perform its
shutdown; if < 0 (the default) it means this method was not called during shutdown but otherwise and
a default value (60 seconds currently) will be usedpublic void stop(java.util.concurrent.CountDownLatch latch)
public void stop(java.util.concurrent.CountDownLatch latch, int waitTimeoutInSecs)
public void processDBManEvent(DBManEvent event)
DBManEvent
in a parallel thread.processDBManEvent
in interface DBManEventListenerI
event
- the event that came from the serverpublic java.lang.Thread newThread(java.lang.Runnable r)
newThread
in interface java.util.concurrent.ThreadFactory
public int incrementPending()
public int decrementPending()
public java.lang.String getNameForLog()
Thread
implementation containing the standard code to be executed for starting the module. Should not need to
be subclassed, subclasses of ListeningKernelModule
should overwrite ListeningKernelModule#doStart()
and/or ListeningKernelModule#doStartAfterListening()
.public void setNameForLog(java.lang.String $6)
public DBManEventFilter getEventFilter()
public void setEventFilter(DBManEventFilter $7)
public java.util.concurrent.atomic.AtomicInteger getCPending()
public void setCPending(java.util.concurrent.atomic.AtomicInteger $8)
public int getPendingShowLimit()
public void setPendingShowLimit(int $9)
public boolean isActive()
public void setActive(boolean $10)
Copyright © 2000-2025 OAshi S.à r.l. All Rights Reserved.