public class UFC extends FlowControl
FlowControl.Credit
Modifier and Type | Field and Description |
---|---|
protected Average |
avg_block_time |
protected java.util.Map<Address,FlowControl.Credit> |
sent
Map: keys are members, values are credits left.
|
protected static FcHeader |
UFC_CREDIT_REQUEST_HDR |
protected static FcHeader |
UFC_REPLENISH_HDR |
frag_size, ignore_synchronous_response, local_addr, max_block_time, max_block_times, max_credits, min_credits, min_threshold, num_credit_requests_received, num_credit_requests_sent, num_credit_responses_received, num_credit_responses_sent, received, running
after_creation_hook, down_prot, ergonomics, id, log, name, stack, stats, up_prot
Constructor and Description |
---|
UFC() |
Modifier and Type | Method and Description |
---|---|
java.util.Map<java.lang.String,java.lang.Object> |
dumpStats() |
double |
getAverageTimeBlocked() |
protected Header |
getCreditRequestHeader() |
int |
getNumberOfBlockings() |
protected Header |
getReplenishHeader() |
protected void |
handleCredit(Address sender,
long increase) |
protected java.lang.Object |
handleDownMessage(Event evt,
Message msg,
Address dest,
int length) |
protected boolean |
handleMulticastMessage()
Whether the protocol handles message with dest == null || dest.isMulticastAddress()
|
protected void |
handleViewChange(java.util.List<Address> mbrs) |
void |
init()
Called after instance has been created (null constructor) and before protocol is started.
|
java.lang.String |
printCredits() |
java.lang.String |
printSenderCredits() |
void |
resetStats() |
void |
stop()
This method is called on a
Channel.disconnect() . |
void |
unblock()
Allows to unblock all blocked senders from an external program, e.g.
|
adjustCredit, bufferToLong, down, getMaxBlockTime, getMaxBlockTime, getMaxBlockTimes, getMaxCredits, getMinCredits, getMinThreshold, getNumberOfCreditRequestsReceived, getNumberOfCreditRequestsSent, getNumberOfCreditResponsesReceived, getNumberOfCreditResponsesSent, handleConfigEvent, handleCreditRequest, handleUpEvent, longToBuffer, printMap, printReceiverCredits, sendCredit, sendCreditRequest, setMaxBlockTime, setMaxBlockTimes, setMaxCredits, setMinCredits, setMinThreshold, start, up, up
accept, afterCreationHook, destroy, enableStats, getConfigurableObjects, getDownProtocol, getDownServices, getId, getIdsAbove, getLevel, getLog, getName, getProtocolStack, getSocketFactory, getThreadFactory, getTransport, getUpProtocol, getUpServices, getValue, isErgonomics, level, parse, printStats, providedDownServices, providedUpServices, requiredDownServices, requiredUpServices, resetStatistics, setDownProtocol, setErgonomics, setId, setLevel, setProtocolStack, setSocketFactory, setUpProtocol, setValue, setValues, statsEnabled
protected static final FcHeader UFC_REPLENISH_HDR
protected static final FcHeader UFC_CREDIT_REQUEST_HDR
protected final java.util.Map<Address,FlowControl.Credit> sent
protected final Average avg_block_time
public java.lang.String printSenderCredits()
printSenderCredits
in class FlowControl
public java.lang.String printCredits()
printCredits
in class FlowControl
public java.util.Map<java.lang.String,java.lang.Object> dumpStats()
dumpStats
in class FlowControl
protected boolean handleMulticastMessage()
FlowControl
handleMulticastMessage
in class FlowControl
protected Header getReplenishHeader()
getReplenishHeader
in class FlowControl
protected Header getCreditRequestHeader()
getCreditRequestHeader
in class FlowControl
public void unblock()
FlowControl
unblock
in class FlowControl
public int getNumberOfBlockings()
getNumberOfBlockings
in class FlowControl
public double getAverageTimeBlocked()
getAverageTimeBlocked
in class FlowControl
public void init() throws java.lang.Exception
Protocol
init
in class FlowControl
java.lang.Exception
- Thrown if protocol cannot be initialized successfully. This will cause the
ProtocolStack to fail, so the channel constructor will throw an exceptionpublic void stop()
Protocol
Channel.disconnect()
. Stops work (e.g. by closing multicast socket).
Will be called from top to bottom. This means that at the time of the method invocation the
neighbor protocol below is still working. This method will replace the
STOP, STOP_OK, CLEANUP and CLEANUP_OK events. The ProtocolStack guarantees that
when this method is called all messages in the down queue will have been flushedstop
in class FlowControl
public void resetStats()
resetStats
in class FlowControl
protected java.lang.Object handleDownMessage(Event evt, Message msg, Address dest, int length)
handleDownMessage
in class FlowControl
protected void handleViewChange(java.util.List<Address> mbrs)
handleViewChange
in class FlowControl
protected void handleCredit(Address sender, long increase)
handleCredit
in class FlowControl
Copyright © 1998-2020 Red Hat. All Rights Reserved.