org.jgroups.protocols
public class FRAG2 extends Protocol
Each fragment is identified by (a) the sender (part of the message to which the header is appended), (b) the fragmentation ID (which is unique per FRAG2 layer (monotonically increasing) and (c) the fragement ID which ranges from 0 to number_of_fragments-1.
Requirement: lossless delivery (e.g. NAK, ACK). No requirement on ordering. Works for both unicast and
multicast messages.
Compared to FRAG, this protocol does not need to serialize the message in order to break it into
smaller fragments: it looks only at the message's buffer, which is a byte[] array anyway. We assume that the
size addition for headers and src and dest address is minimal when the transport finally has to serialize the
message, so we add a constant (1000 bytes).
Version: $Id: FRAG2.java,v 1.20 2005/08/11 12:43:47 belaban Exp $
Method Summary | |
---|---|
void | down(Event evt)
Fragment a packet if larger than frag_size (add a header). |
int | getFragSize() |
String | getName() |
long | getNumberOfReceivedFragments() |
long | getNumberOfReceivedMessages() |
long | getNumberOfSentFragments() |
long | getNumberOfSentMessages() |
int | getOverhead() |
void | resetStats() |
void | setFragSize(int s) |
void | setOverhead(int o) |
boolean | setProperties(Properties props) Setup the Protocol instance acording to the configuration string |
void | up(Event evt)
If event is a message, if it is fragmented, re-assemble fragments into big message and pass up
the stack. |