Class MessageDispatchInterceptor
java.lang.Object
org.apache.catalina.tribes.group.ChannelInterceptorBase
org.apache.catalina.tribes.group.interceptors.MessageDispatchInterceptor
- All Implemented Interfaces:
- ChannelInterceptor,- MessageDispatchInterceptorMBean,- Heartbeat,- MembershipListener
public class MessageDispatchInterceptor
extends ChannelInterceptorBase
implements MessageDispatchInterceptorMBean
The message dispatcher is a way to enable asynchronous communication through a channel. The dispatcher will look for
 the 
Channel.SEND_OPTIONS_ASYNCHRONOUS flag to be set, if it is, it will queue the message for delivery
 and immediately return to the sender.- 
Nested Class SummaryNested classes/interfaces inherited from interface org.apache.catalina.tribes.ChannelInterceptorChannelInterceptor.InterceptorEvent
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected booleanprotected final AtomicLongprotected ExecutorServiceprotected longprotected longprotected intprotected intprotected booleanprotected static final StringManagerprotected booleanFields inherited from class org.apache.catalina.tribes.group.ChannelInterceptorBaseoptionFlag
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionlongaddAndGetCurrentSize(long inc) booleanaddToQueue(ChannelMessage msg, Member[] destination, InterceptorPayload payload) intReturn the current number of threads that are in use.longReturn the total number of tasks that have completed execution by the pool.longlonglongintintintReturn the current number of threads that are managed by the pool.longReturn the total number of tasks that have ever been scheduled for execution by the pool.booleanbooleanprotected voidsendAsyncData(ChannelMessage msg, Member[] destination, InterceptorPayload payload) voidsendMessage(Member[] destination, ChannelMessage msg, InterceptorPayload payload) ThesendMessagemethod is called when a message is being sent to one more destinations.voidsetAlwaysSend(boolean alwaysSend) longsetAndGetCurrentSize(long value) voidsetKeepAliveTime(long keepAliveTime) voidsetMaxQueueSize(long maxQueueSize) voidsetMaxSpareThreads(int maxSpareThreads) voidsetMaxThreads(int maxThreads) voidsetOptionFlag(int flag) Sets the option flagvoidsetUseDeepClone(boolean useDeepClone) voidstart(int svc) Starts up the channel.voidvoidstop(int svc) Shuts down the channel.voidMethods inherited from class org.apache.catalina.tribes.group.ChannelInterceptorBasefireInterceptorEvent, getChannel, getLocalMember, getMember, getMembers, getNext, getOptionFlag, getPrevious, hasMembers, heartbeat, memberAdded, memberDisappeared, messageReceived, okToProcess, setChannel, setNext, setPreviousMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.apache.catalina.tribes.group.interceptors.MessageDispatchInterceptorMBeangetOptionFlag
- 
Field Details- 
sm
- 
maxQueueSizeprotected long maxQueueSize
- 
runprotected volatile boolean run
- 
useDeepCloneprotected boolean useDeepClone
- 
alwaysSendprotected boolean alwaysSend
- 
currentSize
- 
executor
- 
maxThreadsprotected int maxThreads
- 
maxSpareThreadsprotected int maxSpareThreads
- 
keepAliveTimeprotected long keepAliveTime
 
- 
- 
Constructor Details- 
MessageDispatchInterceptorpublic MessageDispatchInterceptor()
 
- 
- 
Method Details- 
sendMessagepublic void sendMessage(Member[] destination, ChannelMessage msg, InterceptorPayload payload) throws ChannelException Description copied from interface:ChannelInterceptorThesendMessagemethod is called when a message is being sent to one more destinations. The interceptor can modify any of the parameters and then pass on the message down the stack by invokinggetNext().sendMessage(destination,msg,payload).Alternatively the interceptor can stop the message from being sent by not invoking getNext().sendMessage(destination,msg,payload).If the message is to be sent asynchronous the application can be notified of completion and errors by passing in an error handler attached to a payload object. The ChannelMessage.getAddress contains Channel.getLocalMember, and can be overwritten to simulate a message sent from another node. - Specified by:
- sendMessagein interface- ChannelInterceptor
- Overrides:
- sendMessagein class- ChannelInterceptorBase
- Parameters:
- destination- Member[] - the destination for this message
- msg- ChannelMessage - the message to be sent
- payload- InterceptorPayload - the payload, carrying an error handler and future useful data, can be null
- Throws:
- ChannelException- if a serialization error happens.
- See Also:
 
- 
addToQueue
- 
startQueuepublic void startQueue()
- 
stopQueuepublic void stopQueue()
- 
setOptionFlagpublic void setOptionFlag(int flag) Description copied from interface:ChannelInterceptorSets the option flag- Specified by:
- setOptionFlagin interface- ChannelInterceptor
- Overrides:
- setOptionFlagin class- ChannelInterceptorBase
- Parameters:
- flag- int
- See Also:
 
- 
setMaxQueueSizepublic void setMaxQueueSize(long maxQueueSize) 
- 
setUseDeepClonepublic void setUseDeepClone(boolean useDeepClone) 
- 
getMaxQueueSizepublic long getMaxQueueSize()- Specified by:
- getMaxQueueSizein interface- MessageDispatchInterceptorMBean
 
- 
getUseDeepClonepublic boolean getUseDeepClone()
- 
getCurrentSizepublic long getCurrentSize()- Specified by:
- getCurrentSizein interface- MessageDispatchInterceptorMBean
 
- 
addAndGetCurrentSizepublic long addAndGetCurrentSize(long inc) 
- 
setAndGetCurrentSizepublic long setAndGetCurrentSize(long value) 
- 
getKeepAliveTimepublic long getKeepAliveTime()- Specified by:
- getKeepAliveTimein interface- MessageDispatchInterceptorMBean
 
- 
getMaxSpareThreadspublic int getMaxSpareThreads()- Specified by:
- getMaxSpareThreadsin interface- MessageDispatchInterceptorMBean
 
- 
getMaxThreadspublic int getMaxThreads()- Specified by:
- getMaxThreadsin interface- MessageDispatchInterceptorMBean
 
- 
setKeepAliveTimepublic void setKeepAliveTime(long keepAliveTime) 
- 
setMaxSpareThreadspublic void setMaxSpareThreads(int maxSpareThreads) 
- 
setMaxThreadspublic void setMaxThreads(int maxThreads) 
- 
isAlwaysSendpublic boolean isAlwaysSend()- Specified by:
- isAlwaysSendin interface- MessageDispatchInterceptorMBean
 
- 
setAlwaysSendpublic void setAlwaysSend(boolean alwaysSend) - Specified by:
- setAlwaysSendin interface- MessageDispatchInterceptorMBean
 
- 
startDescription copied from interface:ChannelInterceptorStarts up the channel. This can be called multiple times for individual services to start The svc parameter can be the logical or value of any constants- Specified by:
- startin interface- ChannelInterceptor
- Overrides:
- startin class- ChannelInterceptorBase
- Parameters:
- svc- one of:- Channel.DEFAULT - will start all services
- Channel.MBR_RX_SEQ - starts the membership receiver
- Channel.MBR_TX_SEQ - starts the membership broadcaster
- Channel.SND_TX_SEQ - starts the replication transmitter
- Channel.SND_RX_SEQ - starts the replication receiver
 
- Throws:
- ChannelException- if a startup error occurs or the service is already started.
- See Also:
 
- 
stopDescription copied from interface:ChannelInterceptorShuts down the channel. This can be called multiple times for individual services to shutdown The svc parameter can be the logical or value of any constants- Specified by:
- stopin interface- ChannelInterceptor
- Overrides:
- stopin class- ChannelInterceptorBase
- Parameters:
- svc- one of:- Channel.DEFAULT - will shutdown all services
- Channel.MBR_RX_SEQ - stops the membership receiver
- Channel.MBR_TX_SEQ - stops the membership broadcaster
- Channel.SND_TX_SEQ - stops the replication transmitter
- Channel.SND_RX_SEQ - stops the replication receiver
 
- Throws:
- ChannelException- if a startup error occurs or the service is already started.
- See Also:
 
- 
sendAsyncData
- 
getPoolSizepublic int getPoolSize()Return the current number of threads that are managed by the pool.- Specified by:
- getPoolSizein interface- MessageDispatchInterceptorMBean
- Returns:
- the current number of threads that are managed by the pool
 
- 
getActiveCountpublic int getActiveCount()Return the current number of threads that are in use.- Specified by:
- getActiveCountin interface- MessageDispatchInterceptorMBean
- Returns:
- the current number of threads that are in use
 
- 
getTaskCountpublic long getTaskCount()Return the total number of tasks that have ever been scheduled for execution by the pool.- Specified by:
- getTaskCountin interface- MessageDispatchInterceptorMBean
- Returns:
- the total number of tasks that have ever been scheduled for execution by the pool
 
- 
getCompletedTaskCountpublic long getCompletedTaskCount()Return the total number of tasks that have completed execution by the pool.- Specified by:
- getCompletedTaskCountin interface- MessageDispatchInterceptorMBean
- Returns:
- the total number of tasks that have completed execution by the pool
 
 
-