Package org.jgroups.protocols
Class RED
java.lang.Object
org.jgroups.stack.Protocol
org.jgroups.protocols.RED
- All Implemented Interfaces:
Lifecycle
Implementation of Random Early Drop: messages are discarded when the bundler's queue in the transport nears exhaustion.
See Floyd and Van Jacobsen's paper for details.
- Since:
- 5.0.0, 4.2.2
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected doubleprotected Bundlerprotected final LongAdderprotected booleanprotected final Lockprotected longprotected doubleprotected longprotected doubleprotected intprotected longprotected final LongAdderprotected doubleprotected doubleFields inherited from class org.jgroups.stack.Protocol
after_creation_hook, down_prot, ergonomics, id, local_addr, log, policies, stack, stats, up_prot -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected static doublecheckRange(double val, double min, double max, String name) protected doublecomputeAverage(double old_avg, int new_queue_size) protected doublecomputeDropProbability(double avg) Computes a probability P with which the message should get dropped.A message is sent down the stack.protected booleandrop(double avg) longDeprecated.doubledoublelongDeprecated.booleanvoidsetEnabled(boolean e) voidstart()This method is called on aJChannel.connect(String); starts work.toString()voidup(MessageBatch batch) Sends up a multiple messages in aMessageBatch.Methods inherited from class org.jgroups.stack.Protocol
accept, addPolicy, addr, addr, afterCreationHook, destroy, down, down, enableStats, getAddress, getComponents, getDownProtocol, getDownServices, getId, getIdsAbove, getLevel, getLog, getName, getPolicies, getProtocolStack, getSocketFactory, getThreadFactory, getTransport, getUpProtocol, getUpServices, getValue, init, isErgonomics, level, parse, policies, providedDownServices, providedUpServices, removePolicy, requiredDownServices, requiredUpServices, resetStatistics, setAddress, setDownProtocol, setErgonomics, setId, setLevel, setPolicies, setProtocolStack, setSocketFactory, setUpProtocol, setValue, statsEnabled, stop, up, up
-
Field Details
-
enabled
protected boolean enabled -
queue_capacity
protected int queue_capacity -
min_threshold
protected double min_threshold -
min
protected long min -
max_threshold
protected double max_threshold -
max
protected long max -
avg_queue_size
protected double avg_queue_size -
weight_factor
protected double weight_factor -
dropped_msgs
-
total_msgs
-
bundler
-
lock
-
span
protected long span -
weight
protected double weight
-
-
Constructor Details
-
RED
public RED()
-
-
Method Details
-
isEnabled
public boolean isEnabled() -
setEnabled
-
getMinThreshold
public double getMinThreshold() -
getDroppedMessages
Deprecated.Don't remove! https://issues.redhat.com/browse/JGRP-2814 -
getTotalMessages
Deprecated.Don't remove! https://issues.redhat.com/browse/JGRP-2814 -
getDropRate
public double getDropRate() -
start
Description copied from class:ProtocolThis method is called on aJChannel.connect(String); starts work. Protocols are connected ready to receive events. Will be called from bottom to top. -
resetStats
public void resetStats()- Overrides:
resetStatsin classProtocol
-
down
Description copied from class:ProtocolA message is sent down the stack. Protocols may examine the message and do something (e.g. add a header) with it, before passing it down. -
up
Description copied from class:ProtocolSends up a multiple messages in aMessageBatch. The sender of the batch is always the same, and so is the destination (null == multicast messages). Messages in a batch can be OOB messages, regular messages, or mixed messages, although the transport itself will create initial MessageBatches that contain only either OOB or regular messages.The default processing below sends messages up the stack individually, based on a matching criteria (calling
Protocol.accept(Message)), and - if true - callsProtocol.up(org.jgroups.Event)for that message and removes the message. If the batch is not empty, it is passed up, or else it is dropped.Subclasses should check if there are any messages destined for them (e.g. using
MessageBatch.iterator(Predicate)), then possibly remove and process them and finally pass the batch up to the next protocol. Protocols can also modify messages in place, e.g. ENCRYPT could decrypt all encrypted messages in the batch, not remove them, and pass the batch up when done. -
toString
-
computeAverage
protected double computeAverage(double old_avg, int new_queue_size) -
computeDropProbability
protected double computeDropProbability(double avg) Computes a probability P with which the message should get dropped. min_threshold < avg < max_threshold. Probability increases linearly with min moving toward max -
drop
protected boolean drop(double avg) -
checkRange
-