Package org.apache.catalina.ha.session
Class DeltaManager
java.lang.Object
org.apache.catalina.util.LifecycleBase
org.apache.catalina.util.LifecycleMBeanBase
org.apache.catalina.session.ManagerBase
org.apache.catalina.ha.session.ClusterManagerBase
org.apache.catalina.ha.session.DeltaManager
- All Implemented Interfaces:
- MBeanRegistration,- ClusterManager,- JmxEnabled,- Lifecycle,- Manager
The DeltaManager manages replicated sessions by only replicating the deltas in data. For applications written to
 handle this, the DeltaManager is the optimal way of replicating data.
 
This code is almost identical to StandardManager with a difference in how it persists sessions and some modifications to it.
 IMPLEMENTATION NOTE : Correct behavior of session storing and reloading depends upon external calls to the
 start() and stop() methods of this class at the correct times.
- Author:
- Craig R. McClanahan, Peter Rossbach
- 
Nested Class SummaryNested classes/interfaces inherited from class org.apache.catalina.session.ManagerBaseManagerBase.SessionTimingNested classes/interfaces inherited from interface org.apache.catalina.LifecycleLifecycle.SingleUse
- 
Field SummaryFieldsModifier and TypeFieldDescriptionfinal Logprotected static final StringDeprecated.Unused.protected Stringprotected static final StringManagerThe string manager for this package.Fields inherited from class org.apache.catalina.ha.session.ClusterManagerBaseclusterFields inherited from class org.apache.catalina.session.ManagerBaseduplicates, expiredSessions, maxActive, maxActiveSessions, processExpiresFrequency, processingTime, rejectedSessions, secureRandomAlgorithm, secureRandomClass, secureRandomProvider, sessionCounter, sessionCreationTiming, sessionExpirationTiming, sessionIdGenerator, sessionIdGeneratorClass, sessionMaxAliveTime, sessions, support, TIMING_STATS_CACHE_SIZEFields inherited from class org.apache.catalina.util.LifecycleMBeanBasemserverFields inherited from interface org.apache.catalina.LifecycleAFTER_DESTROY_EVENT, AFTER_INIT_EVENT, AFTER_START_EVENT, AFTER_STOP_EVENT, BEFORE_DESTROY_EVENT, BEFORE_INIT_EVENT, BEFORE_START_EVENT, BEFORE_STOP_EVENT, CONFIGURE_START_EVENT, CONFIGURE_STOP_EVENT, PERIODIC_EVENT, START_EVENT, STOP_EVENT
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidchangeSessionId(Session session) Change the session ID of the current session to a new randomly generated session ID.protected voidchangeSessionId(Session session, boolean notify) Deprecated.Will be removed in Tomcat 10voidchangeSessionId(Session session, String newId) Change the session ID of the current session to a specified session ID.protected voidchangeSessionId(Session session, String newId, boolean notify) Get a session from the recycled ones or create a new empty one.createSession(String sessionId) Construct and return a new session object, based on the default settings specified by this Manager's properties.createSession(String sessionId, boolean distribute) Create new session with check maxActiveSessions and send session creation to other cluster nodes.protected DeltaRequestdeserializeDeltaRequest(DeltaSession session, byte[] data) Deprecated.Unused.protected StringdeserializeSessionId(byte[] data) Load sessionIDprotected voiddeserializeSessions(byte[] data) Load sessions from other cluster node.voidExpire all find sessions.protected MemberFind the master of the session statevoidget from first session master the backup from all clustered sessionsintDeprecated.intlonglongintlonglonglonglonglonglonglongintlonglonglonglonglonglongString[]When the manager expires session not tied to a request.getName()Return the name of the manager, at host /context name and at engine hostname+/context.protected DeltaSessionDeprecated.Unused.intintintlongbooleanDeprecated.booleanintprotected voidhandleALL_SESSION_DATA(SessionMessage msg, Member sender) handle receive sessions from other not ( restart )protected voidhandleALL_SESSION_NOCONTEXTMANAGER(SessionMessage msg, Member sender) handle receive no context manager.protected voidhandleALL_SESSION_TRANSFERCOMPLETE(SessionMessage msg, Member sender) handle receive session state is complete transferredprotected voidhandleCHANGE_SESSION_ID(SessionMessage msg, Member sender) handle receive change sessionID at other nodeprotected voidhandleGET_ALL_SESSIONS(SessionMessage msg, Member sender) Handle a get all sessions message from another node.protected voidhandleSESSION_ACCESSED(SessionMessage msg, Member sender) handle receive session is access at other node ( primary session is now false)protected voidhandleSESSION_CREATED(SessionMessage msg, Member sender) handle receive new session is created at other node (create backup - primary false)protected voidhandleSESSION_DELTA(SessionMessage msg, Member sender) handle receive session deltaprotected voidhandleSESSION_EXPIRED(SessionMessage msg, Member sender) handle receive session is expire at other node ( expire session also here)booleanbooleanbooleanbooleanbooleanbooleanvoidA message was received from another node, this is the callback method to implement if you are interested in receiving replication messages.protected voidmessageReceived(SessionMessage msg, Member sender) This method is called by the received thread when a SessionMessage has been received from one of the other nodes in the cluster.requestCompleted(String sessionId) When the request has been completed, the replication valve will notify the manager, and the manager will decide whether any replication is needed or not.requestCompleted(String sessionId, boolean expires) When the request has been completed, the replication valve will notify the manager, and the manager will decide whether any replication is needed or not.voidReset manager statisticsrotateSessionId(Session session) protected StringrotateSessionId(Session session, boolean notify) protected voidsend(SessionMessage msg) Send messages to other backup member (domain or all)protected voidsendChangeSessionId(String newSessionID, String orgSessionID) protected voidsendCreateSession(String sessionId, DeltaSession session) Send create session event to all backup nodeprotected voidsendSessions(Member sender, Session[] currentSessions, long sendTimestamp) send a block of session to senderprotected byte[]serializeDeltaRequest(DeltaSession session, DeltaRequest deltaRequest) Deprecated.Unused.protected byte[]serializeSessionId(String sessionId) serialize sessionIDprotected byte[]serializeSessions(Session[] currentSessions) Save any currently active sessions in the appropriate persistence mechanism, if any.protected voidsessionExpired(String id) send session expired to other cluster nodesvoidsetExpireSessionsOnShutdown(boolean expireSessionsOnShutdown) voidSet the name of the manager, at host /context name and at engine hostname+/contextvoidsetNoContextManagerReceived(boolean noContextManagerReceived) voidsetNotifyContainerListenersOnReplication(boolean notifyContainerListenersOnReplication) voidsetNotifySessionListenersOnReplication(boolean notifyListenersCreateSessionOnReplication) voidsetSendAllSessions(boolean sendAllSessions) voidsetSendAllSessionsSize(int sendAllSessionsSize) voidsetSendAllSessionsWaitTime(int sendAllSessionsWaitTime) voidsetStateTimestampDrop(boolean isTimestampDrop) voidsetStateTransfered(boolean stateTransferred) Deprecated.voidsetStateTransferred(boolean stateTransferred) Set that state transferred is completevoidsetStateTransferTimeout(int timeoutAllSession) protected voidStart this component and implement the requirements ofLifecycleBase.startInternal().protected voidStop this component and implement the requirements ofLifecycleBase.stopInternal().protected voidwaitForSendAllSessions(long beforeSendTime) Wait that cluster session state is transferred or timeout after 60 Sec With stateTransferTimeout == -1 wait that backup is transferred (forever mode)Methods inherited from class org.apache.catalina.ha.session.ClusterManagerBaseclone, getClassLoaders, getClassLoaders, getCluster, getDeltaRequestPool, getReplicationStream, getReplicationStream, isNotifyListenersOnReplication, isRecordAllActions, load, registerSessionAtReplicationValve, setCluster, setNotifyListenersOnReplication, setRecordAllActions, unloadMethods inherited from class org.apache.catalina.session.ManagerBaseadd, addPropertyChangeListener, backgroundProcess, changeSessionId, expireSession, findSession, findSessions, generateSessionId, getActiveSessions, getClassName, getContext, getCreationTime, getCreationTimestamp, getDomainInternal, getDuplicates, getEngine, getExpiredSessions, getJvmRoute, getLastAccessedTime, getLastAccessedTimestamp, getMaxActive, getMaxActiveSessions, getNewSession, getObjectNameKeyProperties, getPersistAuthentication, getPersistAuthenticationNotes, getProcessExpiresFrequency, getProcessingTime, getRejectedSessions, getSecureRandomAlgorithm, getSecureRandomClass, getSecureRandomProvider, getSession, getSessionAttribute, getSessionAttributeNameFilter, getSessionAttributeNamePattern, getSessionAttributeValueClassNameFilter, getSessionAttributeValueClassNamePattern, getSessionAverageAliveTime, getSessionCounter, getSessionCreateRate, getSessionExpireRate, getSessionIdGenerator, getSessionMaxAliveTime, getThisAccessedTime, getThisAccessedTimestamp, getWarnOnSessionAttributeFilterFailure, initInternal, listSessionIds, processExpires, remove, remove, removePropertyChangeListener, setContext, setDuplicates, setExpiredSessions, setMaxActive, setMaxActiveSessions, setPersistAuthentication, setPersistAuthenticationNotes, setProcessExpiresFrequency, setProcessingTime, setSecureRandomAlgorithm, setSecureRandomClass, setSecureRandomProvider, setSessionAttributeNameFilter, setSessionAttributeValueClassNameFilter, setSessionCounter, setSessionIdGenerator, setSessionMaxAliveTime, setWarnOnSessionAttributeFilterFailure, toString, updateSessionMaxAliveTime, willAttributeDistributeMethods inherited from class org.apache.catalina.util.LifecycleMBeanBasedestroyInternal, getDomain, getObjectName, postDeregister, postRegister, preDeregister, preRegister, register, setDomain, unregisterMethods inherited from class org.apache.catalina.util.LifecycleBaseaddLifecycleListener, destroy, findLifecycleListeners, fireLifecycleEvent, getState, getStateName, getThrowOnFailure, init, removeLifecycleListener, setState, setState, setThrowOnFailure, start, stopMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.apache.catalina.Manageradd, addPropertyChangeListener, backgroundProcess, findSession, findSessions, getActiveSessions, getContext, getExpiredSessions, getMaxActive, getRejectedSessions, getSessionAverageAliveTime, getSessionCounter, getSessionCreateRate, getSessionExpireRate, getSessionIdGenerator, getSessionMaxAliveTime, remove, remove, removePropertyChangeListener, setContext, setExpiredSessions, setMaxActive, setSessionCounter, setSessionIdGenerator, setSessionMaxAliveTime, willAttributeDistribute
- 
Field Details- 
log
- 
smThe string manager for this package.
- 
managerNameDeprecated.Unused. Will be removed in Tomcat 9The descriptive name of this Manager implementation (for logging).- See Also:
 
- 
name
 
- 
- 
Constructor Details- 
DeltaManagerpublic DeltaManager()
 
- 
- 
Method Details- 
setNameDescription copied from interface:ClusterManagerSet the name of the manager, at host /context name and at engine hostname+/context- Parameters:
- name- The manager name
 
- 
getNameDescription copied from interface:ClusterManagerReturn the name of the manager, at host /context name and at engine hostname+/context.- Specified by:
- getNamein interface- ClusterManager
- Overrides:
- getNamein class- ManagerBase
- Returns:
- The descriptive short name of this Manager implementation.
 
- 
getCounterSend_EVT_GET_ALL_SESSIONSpublic long getCounterSend_EVT_GET_ALL_SESSIONS()- Returns:
- Returns the counterSend_EVT_GET_ALL_SESSIONS.
 
- 
getCounterSend_EVT_SESSION_ACCESSEDpublic long getCounterSend_EVT_SESSION_ACCESSED()- Returns:
- Returns the counterSend_EVT_SESSION_ACCESSED.
 
- 
getCounterSend_EVT_SESSION_CREATEDpublic long getCounterSend_EVT_SESSION_CREATED()- Returns:
- Returns the counterSend_EVT_SESSION_CREATED.
 
- 
getCounterSend_EVT_SESSION_DELTApublic long getCounterSend_EVT_SESSION_DELTA()- Returns:
- Returns the counterSend_EVT_SESSION_DELTA.
 
- 
getCounterSend_EVT_SESSION_EXPIREDpublic long getCounterSend_EVT_SESSION_EXPIRED()- Returns:
- Returns the counterSend_EVT_SESSION_EXPIRED.
 
- 
getCounterSend_EVT_ALL_SESSION_DATApublic long getCounterSend_EVT_ALL_SESSION_DATA()- Returns:
- Returns the counterSend_EVT_ALL_SESSION_DATA.
 
- 
getCounterSend_EVT_ALL_SESSION_TRANSFERCOMPLETEpublic int getCounterSend_EVT_ALL_SESSION_TRANSFERCOMPLETE()- Returns:
- Returns the counterSend_EVT_ALL_SESSION_TRANSFERCOMPLETE.
 
- 
getCounterSend_EVT_CHANGE_SESSION_IDpublic long getCounterSend_EVT_CHANGE_SESSION_ID()- Returns:
- Returns the counterSend_EVT_CHANGE_SESSION_ID.
 
- 
getCounterReceive_EVT_ALL_SESSION_DATApublic long getCounterReceive_EVT_ALL_SESSION_DATA()- Returns:
- Returns the counterReceive_EVT_ALL_SESSION_DATA.
 
- 
getCounterReceive_EVT_GET_ALL_SESSIONSpublic long getCounterReceive_EVT_GET_ALL_SESSIONS()- Returns:
- Returns the counterReceive_EVT_GET_ALL_SESSIONS.
 
- 
getCounterReceive_EVT_SESSION_ACCESSEDpublic long getCounterReceive_EVT_SESSION_ACCESSED()- Returns:
- Returns the counterReceive_EVT_SESSION_ACCESSED.
 
- 
getCounterReceive_EVT_SESSION_CREATEDpublic long getCounterReceive_EVT_SESSION_CREATED()- Returns:
- Returns the counterReceive_EVT_SESSION_CREATED.
 
- 
getCounterReceive_EVT_SESSION_DELTApublic long getCounterReceive_EVT_SESSION_DELTA()- Returns:
- Returns the counterReceive_EVT_SESSION_DELTA.
 
- 
getCounterReceive_EVT_SESSION_EXPIREDpublic long getCounterReceive_EVT_SESSION_EXPIRED()- Returns:
- Returns the counterReceive_EVT_SESSION_EXPIRED.
 
- 
getCounterReceive_EVT_ALL_SESSION_TRANSFERCOMPLETEpublic int getCounterReceive_EVT_ALL_SESSION_TRANSFERCOMPLETE()- Returns:
- Returns the counterReceive_EVT_ALL_SESSION_TRANSFERCOMPLETE.
 
- 
getCounterReceive_EVT_CHANGE_SESSION_IDpublic long getCounterReceive_EVT_CHANGE_SESSION_ID()- Returns:
- Returns the counterReceive_EVT_CHANGE_SESSION_ID.
 
- 
getCounterReceive_EVT_ALL_SESSION_NOCONTEXTMANAGERpublic long getCounterReceive_EVT_ALL_SESSION_NOCONTEXTMANAGER()- Returns:
- Returns the counterReceive_EVT_ALL_SESSION_NOCONTEXTMANAGER.
 
- 
getSessionReplaceCounterpublic long getSessionReplaceCounter()- Returns:
- Returns the sessionReplaceCounter.
 
- 
getCounterNoStateTransferedDeprecated.UsegetCounterNoStateTransferred(). Will be removed in Tomcat 10 onwards.- Returns:
- Returns the counterNoStateTransferred.
 
- 
getCounterNoStateTransferredpublic int getCounterNoStateTransferred()- Returns:
- Returns the counterNoStateTransferred.
 
- 
getReceivedQueueSizepublic int getReceivedQueueSize()
- 
getStateTransferTimeoutpublic int getStateTransferTimeout()- Returns:
- Returns the stateTransferTimeout.
 
- 
setStateTransferTimeoutpublic void setStateTransferTimeout(int timeoutAllSession) - Parameters:
- timeoutAllSession- The timeout
 
- 
getStateTransferedDeprecated.UsegetStateTransferred(). Will be removed in Tomcat 10 onwards.- Returns:
- trueif the state transfer is complete.
 
- 
setStateTransferedDeprecated.UsesetStateTransferred(boolean). Will be removed in Tomcat 10 onwards.Set that state transferred is complete- Parameters:
- stateTransferred- Flag value
 
- 
getStateTransferredpublic boolean getStateTransferred()- Returns:
- trueif the state transfer is complete.
 
- 
setStateTransferredpublic void setStateTransferred(boolean stateTransferred) Set that state transferred is complete- Parameters:
- stateTransferred- Flag value
 
- 
isNoContextManagerReceivedpublic boolean isNoContextManagerReceived()
- 
setNoContextManagerReceivedpublic void setNoContextManagerReceived(boolean noContextManagerReceived) 
- 
getSendAllSessionsWaitTimepublic int getSendAllSessionsWaitTime()- Returns:
- the sendAllSessionsWaitTime in msec
 
- 
setSendAllSessionsWaitTimepublic void setSendAllSessionsWaitTime(int sendAllSessionsWaitTime) - Parameters:
- sendAllSessionsWaitTime- The sendAllSessionsWaitTime to set at msec.
 
- 
isStateTimestampDroppublic boolean isStateTimestampDrop()- Returns:
- the stateTimestampDrop.
 
- 
setStateTimestampDroppublic void setStateTimestampDrop(boolean isTimestampDrop) - Parameters:
- isTimestampDrop- The new flag value
 
- 
isSendAllSessionspublic boolean isSendAllSessions()- Returns:
- the sendAllSessions.
 
- 
setSendAllSessionspublic void setSendAllSessions(boolean sendAllSessions) - Parameters:
- sendAllSessions- The sendAllSessions to set.
 
- 
getSendAllSessionsSizepublic int getSendAllSessionsSize()- Returns:
- the sendAllSessionsSize.
 
- 
setSendAllSessionsSizepublic void setSendAllSessionsSize(int sendAllSessionsSize) - Parameters:
- sendAllSessionsSize- The sendAllSessionsSize to set.
 
- 
isNotifySessionListenersOnReplicationpublic boolean isNotifySessionListenersOnReplication()- Returns:
- the notifySessionListenersOnReplication.
 
- 
setNotifySessionListenersOnReplicationpublic void setNotifySessionListenersOnReplication(boolean notifyListenersCreateSessionOnReplication) - Parameters:
- notifyListenersCreateSessionOnReplication- The notifySessionListenersOnReplication to set.
 
- 
isExpireSessionsOnShutdownpublic boolean isExpireSessionsOnShutdown()
- 
setExpireSessionsOnShutdownpublic void setExpireSessionsOnShutdown(boolean expireSessionsOnShutdown) 
- 
isNotifyContainerListenersOnReplicationpublic boolean isNotifyContainerListenersOnReplication()
- 
setNotifyContainerListenersOnReplicationpublic void setNotifyContainerListenersOnReplication(boolean notifyContainerListenersOnReplication) 
- 
createSessionDescription copied from interface:ManagerConstruct and return a new session object, based on the default settings specified by this Manager's properties. The session id specified will be used as the session id. If a new session cannot be created for any reason, returnnull.- Specified by:
- createSessionin interface- Manager
- Overrides:
- createSessionin class- ManagerBase
- Parameters:
- sessionId- The session id which should be used to create the new session; if- null, the session id will be assigned by this method, and available via the getId() method of the returned session.
- Returns:
- An empty Session object with the given ID or a newly created session ID if none was specified
 
- 
createSessionCreate new session with check maxActiveSessions and send session creation to other cluster nodes.- Parameters:
- sessionId- The session id that should be used for the session
- distribute-- trueto replicate the new session
- Returns:
- The session
 
- 
sendCreateSessionSend create session event to all backup node- Parameters:
- sessionId- The session id of the session
- session- The session object
 
- 
sendSend messages to other backup member (domain or all)- Parameters:
- msg- Session message
 
- 
createEmptySessionGet a session from the recycled ones or create a new empty one. The PersistentManager manager does not need to create session data because it reads it from the Store.Creates new DeltaSession instance. - Specified by:
- createEmptySessionin interface- Manager
- Overrides:
- createEmptySessionin class- ManagerBase
- Returns:
- An empty Session object
 
- 
getNewDeltaSessionDeprecated.Unused. This will be removed in Tomcat 10.Get new session class to be used in the doLoad() method.- Returns:
- a new session
 
- 
changeSessionIdDescription copied from interface:ManagerChange the session ID of the current session to a new randomly generated session ID.- Specified by:
- changeSessionIdin interface- Manager
- Overrides:
- changeSessionIdin class- ManagerBase
- Parameters:
- session- The session to change the session ID for
 
- 
rotateSessionId- Overrides:
- rotateSessionIdin class- ManagerBase
 
- 
changeSessionIdDescription copied from interface:ManagerChange the session ID of the current session to a specified session ID.- Specified by:
- changeSessionIdin interface- Manager
- Overrides:
- changeSessionIdin class- ManagerBase
- Parameters:
- session- The session to change the session ID for
- newId- new session ID
 
- 
changeSessionIdDeprecated.Will be removed in Tomcat 10- Parameters:
- session- The session
- notify- Notify change
 
- 
rotateSessionId
- 
changeSessionId
- 
sendChangeSessionId
- 
serializeSessionIdserialize sessionID- Parameters:
- sessionId- Session id to serialize
- Returns:
- byte array with serialized session id
- Throws:
- IOException- if an input/output error occurs
 
- 
deserializeSessionIdLoad sessionID- Parameters:
- data- serialized session id
- Returns:
- session id
- Throws:
- IOException- if an input/output error occurs
 
- 
deserializeDeltaRequest@Deprecated protected DeltaRequest deserializeDeltaRequest(DeltaSession session, byte[] data) throws ClassNotFoundException, IOException Deprecated.Unused. This will be removed in Tomcat 10. Calling this method may result in a deadlock. See: https://bz.apache.org/bugzilla/show_bug.cgi?id=62841Load Deltarequest from external node Load the Class at container classloader- Parameters:
- session- Corresponding session
- data- message data
- Returns:
- The request
- Throws:
- ClassNotFoundException- Serialization error
- IOException- IO error with serialization
- See Also:
 
- 
serializeDeltaRequest@Deprecated protected byte[] serializeDeltaRequest(DeltaSession session, DeltaRequest deltaRequest) throws IOException Deprecated.Unused. This will be removed in Tomcat 10. Calling this method may result in a deadlock. See: https://bz.apache.org/bugzilla/show_bug.cgi?id=62841serialize DeltaRequest- Parameters:
- session- Associated session
- deltaRequest- The request to serialize
- Returns:
- serialized delta request
- Throws:
- IOException- IO error with serialization
- See Also:
 
- 
deserializeSessionsLoad sessions from other cluster node.FIXME replace currently sessions with same id without notification. FIXME SSO handling is not really correct with the session replacement! - Parameters:
- data- Serialized data
- Throws:
- ClassNotFoundException- if a serialized class cannot be found during the reload
- IOException- if an input/output error occurs
 
- 
serializeSessionsSave any currently active sessions in the appropriate persistence mechanism, if any. If persistence is not supported, this method returns without doing anything.- Parameters:
- currentSessions- Sessions to serialize
- Returns:
- serialized data
- Throws:
- IOException- if an input/output error occurs
 
- 
startInternalStart this component and implement the requirements ofLifecycleBase.startInternal().- Overrides:
- startInternalin class- ClusterManagerBase
- Throws:
- LifecycleException- if this component detects a fatal error that prevents this component from being used
 
- 
getAllClusterSessionspublic void getAllClusterSessions()get from first session master the backup from all clustered sessions- See Also:
 
- 
findSessionMasterMemberFind the master of the session state- Returns:
- master member of sessions
 
- 
waitForSendAllSessionsprotected void waitForSendAllSessions(long beforeSendTime) Wait that cluster session state is transferred or timeout after 60 Sec With stateTransferTimeout == -1 wait that backup is transferred (forever mode)- Parameters:
- beforeSendTime- Start instant of the operation
 
- 
stopInternalStop this component and implement the requirements ofLifecycleBase.stopInternal().- Overrides:
- stopInternalin class- ClusterManagerBase
- Throws:
- LifecycleException- if this component detects a fatal error that prevents this component from being used
 
- 
messageDataReceivedA message was received from another node, this is the callback method to implement if you are interested in receiving replication messages.- Parameters:
- cmsg- - the message received.
 
- 
requestCompletedWhen the request has been completed, the replication valve will notify the manager, and the manager will decide whether any replication is needed or not. If there is a need for replication, the manager will create a session message and that will be replicated. The cluster determines where it gets sent.- Parameters:
- sessionId- - the sessionId that just completed.
- Returns:
- a SessionMessage to be sent,
 
- 
requestCompletedWhen the request has been completed, the replication valve will notify the manager, and the manager will decide whether any replication is needed or not. If there is a need for replication, the manager will create a session message and that will be replicated. The cluster determines where it gets sent. Session expiration also calls this method, but with expires == true.- Parameters:
- sessionId- - the sessionId that just completed.
- expires- - whether this method has been called during session expiration
- Returns:
- a SessionMessage to be sent,
 
- 
resetStatisticspublic void resetStatistics()Reset manager statistics
- 
sessionExpiredsend session expired to other cluster nodes- Parameters:
- id- session id
 
- 
expireAllLocalSessionspublic void expireAllLocalSessions()Expire all find sessions.
- 
getInvalidatedSessionsDescription copied from interface:ClusterManagerWhen the manager expires session not tied to a request. The cluster will periodically ask for a list of sessions that should expire and that should be sent across the wire.- Returns:
- String[] The invalidated sessions
 
- 
messageReceivedThis method is called by the received thread when a SessionMessage has been received from one of the other nodes in the cluster.- Parameters:
- msg- - the message received
- sender- - the sender of the message, this is used if we receive a EVT_GET_ALL_SESSION message, so that we only reply to the requesting node
 
- 
handleALL_SESSION_TRANSFERCOMPLETEhandle receive session state is complete transferred- Parameters:
- msg- Session message
- sender- Member which sent the message
 
- 
handleSESSION_DELTAprotected void handleSESSION_DELTA(SessionMessage msg, Member sender) throws IOException, ClassNotFoundException handle receive session delta- Parameters:
- msg- Session message
- sender- Member which sent the message
- Throws:
- IOException- IO error with serialization
- ClassNotFoundException- Serialization error
 
- 
handleSESSION_ACCESSEDhandle receive session is access at other node ( primary session is now false)- Parameters:
- msg- Session message
- sender- Member which sent the message
- Throws:
- IOException- Propagated IO error
 
- 
handleSESSION_EXPIREDhandle receive session is expire at other node ( expire session also here)- Parameters:
- msg- Session message
- sender- Member which sent the message
- Throws:
- IOException- Propagated IO error
 
- 
handleSESSION_CREATEDhandle receive new session is created at other node (create backup - primary false)- Parameters:
- msg- Session message
- sender- Member which sent the message
 
- 
handleALL_SESSION_DATAprotected void handleALL_SESSION_DATA(SessionMessage msg, Member sender) throws ClassNotFoundException, IOException handle receive sessions from other not ( restart )- Parameters:
- msg- Session message
- sender- Member which sent the message
- Throws:
- ClassNotFoundException- Serialization error
- IOException- IO error with serialization
 
- 
handleGET_ALL_SESSIONSHandle a get all sessions message from another node. Depending onsendAllSessions, sessions are either sent in a single message or in batches. Sending is complete when this method exits.- Parameters:
- msg- Session message
- sender- Member which sent the message
- Throws:
- IOException- IO error sending messages
 
- 
handleCHANGE_SESSION_IDhandle receive change sessionID at other node- Parameters:
- msg- Session message
- sender- Member which sent the message
- Throws:
- IOException- IO error with serialization
 
- 
handleALL_SESSION_NOCONTEXTMANAGERhandle receive no context manager.- Parameters:
- msg- Session message
- sender- Member which sent the message
 
- 
sendSessionsprotected void sendSessions(Member sender, Session[] currentSessions, long sendTimestamp) throws IOException send a block of session to sender- Parameters:
- sender- Sender member
- currentSessions- Sessions to send
- sendTimestamp- Timestamp
- Throws:
- IOException- IO error sending messages
 
- 
cloneFromTemplate
 
-