Package org.jgroups
Interface Receiver
-
- All Known Implementing Classes:
Chat,Draw,FlowControlTest,JGroupsTransport,LargeState,MessageDispatcherSpeedTest,MessageSendTest,MPerf,MPerfRpc,MyReceiver,PingPong,ProgrammaticUPerf,ProgrammaticUPerf2,RelayDemo,RelayDemoRpc,Relayer.Bridge,ReplCache,ReplicatedHashMap,ReplicatedTree,RoundTripRpc,RpcDispatcherBlocking,RpcDispatcherSpeedTest,UnicastTest.MyReceiver,UnicastTestRpc,UPerf
public interface ReceiverDefines the callbacks that are invoked when messages, views etc are received- Since:
- 2.0
- See Also:
JChannel.setReceiver(Receiver)
-
-
Method Summary
All Methods Instance Methods Default Methods Modifier and Type Method Description default voidblock()Called (usually by theFLUSHprotocol), as an indication that the member should stop sending messages.default voidgetState(java.io.OutputStream output)Allows an application to write the state to an OutputStream.default voidreceive(Message msg)Called when a message is received.default voidreceive(MessageBatch batch)Called when a batch of messages is receiveddefault voidsetState(java.io.InputStream input)Allows an application to read the state from an InputStream.default voidunblock()Called after the FLUSH protocol has unblocked previously blocked senders, and messages can be sent again.default voidviewAccepted(View new_view)Called when a change in membership has occurred.
-
-
-
Method Detail
-
receive
default void receive(Message msg)
Called when a message is received.- Parameters:
msg- The message
-
receive
default void receive(MessageBatch batch)
Called when a batch of messages is received- Parameters:
batch- The message batch
-
viewAccepted
default void viewAccepted(View new_view)
Called when a change in membership has occurred. No long running actions, sending of messages or anything that could block should be done in this callback. If some long running action needs to be performed, it should be done in a separate thread.
Note that on reception of the first view (a new member just joined), the channel will not yet be in the connected state. This only happens whenJChannel.connect(String)returns.
-
block
default void block()
Called (usually by theFLUSHprotocol), as an indication that the member should stop sending messages. Any messages sent after returning from this callback might get blocked by the FLUSH protocol. When the FLUSH protocol is done, and messages can be sent again, the FLUSH protocol will simply unblock all pending messages. If a callback for unblocking is desired, implementunblock().
-
unblock
default void unblock()
Called after the FLUSH protocol has unblocked previously blocked senders, and messages can be sent again.
Note that during new view installation we provide guarantee that unblock invocation strictly follows view installation at some node A belonging to that view. However, some other message M may squeeze in between view and unblock callbacks.
For more details see https://issues.redhat.com/browse/JGRP-986
-
getState
default void getState(java.io.OutputStream output) throws java.lang.ExceptionAllows an application to write the state to an OutputStream. After the state has been written, the OutputStream doesn't need to be closed as stream closing is automatically done when a calling thread returns from this callback.- Parameters:
output- The OutputStream- Throws:
java.lang.Exception- If the streaming fails, any exceptions should be thrown so that the state requester can re-throw them and let the caller know what happened
-
setState
default void setState(java.io.InputStream input) throws java.lang.ExceptionAllows an application to read the state from an InputStream. After the state has been read, the InputStream doesn't need to be closed as stream closing is automatically done when a calling thread returns from this callback.- Parameters:
input- The InputStream- Throws:
java.lang.Exception- If the streaming fails, any exceptions should be thrown so that the state requester can catch them and thus know what happened
-
-