public class UnicastingDispatcher extends AbstractDispatcher
MessageDispatcher
that will attempt to send a
Message
to at most one of its handlers. The handlers will be tried
as determined by the LoadBalancingStrategy
if one is configured. As
soon as one of the handlers accepts the Message, the dispatcher will
return true
and ignore the rest of its handlers.
If the dispatcher has no handlers, a MessageDeliveryException
will be
thrown. If all handlers throw Exceptions, the dispatcher will throw an
AggregateMessageDeliveryException
.
A load-balancing strategy may be provided to this class to control the order in which the handlers will be tried.
logger
Constructor and Description |
---|
UnicastingDispatcher() |
UnicastingDispatcher(java.util.concurrent.Executor executor) |
Modifier and Type | Method and Description |
---|---|
boolean |
dispatch(Message<?> message) |
void |
setFailover(boolean failover)
Specify whether this dispatcher should failover when a single
MessageHandler throws an Exception. |
void |
setLoadBalancingStrategy(LoadBalancingStrategy loadBalancingStrategy)
Provide a
LoadBalancingStrategy for this dispatcher. |
addHandler, getHandlerCount, getHandlers, removeHandler, setMaxSubscribers, toString
public UnicastingDispatcher()
public UnicastingDispatcher(java.util.concurrent.Executor executor)
public void setFailover(boolean failover)
MessageHandler
throws an Exception. The default value is
true
.public void setLoadBalancingStrategy(LoadBalancingStrategy loadBalancingStrategy)
LoadBalancingStrategy
for this dispatcher.public final boolean dispatch(Message<?> message)