| java.lang.Object org.apache.catalina.tribes.transport.AbstractRxTask org.apache.catalina.tribes.transport.nio.NioReplicationTask
NioReplicationTask | public class NioReplicationTask extends AbstractRxTask (Code) | | A worker thread class which can drain channels and echo-back the input. Each
instance is constructed with a reference to the owning thread pool object.
When started, the thread loops forever waiting to be awakened to service the
channel associated with a SelectionKey object. The worker is tasked by
calling its serviceChannel() method with a SelectionKey object. The
serviceChannel() method stores the key reference in the thread object then
calls notify() to wake it up. When the channel has been drained, the worker
thread returns itself to its parent pool.
author: Filip Hanik version: $Revision: 546955 $, $Date: 2007-06-13 19:00:21 +0200 (mer., 13 juin 2007) $ |
drainChannel | protected void drainChannel(SelectionKey key, ObjectReader reader) throws Exception(Code) | | The actual code which drains the channel associated with
the given key. This method assumes the key has been
modified prior to invocation to turn off selection
interest in OP_READ. When this method completes it
re-enables OP_READ and calls wakeup() on the selector
so the selector will resume watching this channel.
|
getRxBufSize | public int getRxBufSize()(Code) | | |
run | public synchronized void run()(Code) | | |
sendAck | protected void sendAck(SelectionKey key, SocketChannel channel, byte[] command)(Code) | | send a reply-acknowledgement (6,2,3)
Parameters: key - Parameters: channel - |
serviceChannel | public synchronized void serviceChannel(SelectionKey key)(Code) | | Called to initiate a unit of work by this worker thread
on the provided SelectionKey object. This method is
synchronized, as is the run() method, so only one key
can be serviced at a given time.
Before waking the worker thread, and before returning
to the main selection loop, this key's interest set is
updated to remove OP_READ. This will cause the selector
to ignore read-readiness for this channel while the
worker thread is servicing it.
|
setRxBufSize | public void setRxBufSize(int rxBufSize)(Code) | | |
Fields inherited from org.apache.catalina.tribes.transport.AbstractRxTask | final public static int OPTION_DIRECT_BUFFER(Code)(Java Doc) protected boolean useBufferPool(Code)(Java Doc)
|
|
|