Spring Integration

org.springframework.integration.ip.udp
Class UnicastSendingMessageHandler

java.lang.Object
  extended by org.springframework.integration.context.IntegrationObjectSupport
      extended by org.springframework.integration.handler.AbstractMessageHandler
          extended by org.springframework.integration.ip.AbstractInternetProtocolSendingMessageHandler
              extended by org.springframework.integration.ip.udp.UnicastSendingMessageHandler
All Implemented Interfaces:
Runnable, BeanFactoryAware, BeanNameAware, InitializingBean, Ordered, NamedComponent, MessageHandler, TrackableComponent, CommonSocketOptions
Direct Known Subclasses:
MulticastSendingMessageHandler

public class UnicastSendingMessageHandler
extends AbstractInternetProtocolSendingMessageHandler
implements Runnable

A MessageHandler implementation that maps a Message into a UDP datagram packet and sends that to the specified host and port. Messages can be basic, with no support for reliability, can be prefixed by a length so the receiving end can detect truncation, and can require a UDP acknowledgment to confirm delivery.

Since:
2.0
Author:
Gary Russell

Field Summary
protected  Map<String,CountDownLatch> ackControl
           
protected  int ackCounter
           
protected  boolean acknowledge
           
protected  int ackPort
           
protected  int ackTimeout
           
protected  Exception fatalException
           
protected  String localAddress
           
protected  DatagramPacketMessageMapper mapper
           
protected  DatagramSocket socket
           
protected  int soReceiveBufferSize
           
protected  Executor taskExecutor
           
protected  boolean waitForAck
          If true adds headers to instruct receiving adapter to return an ack.
 
Fields inherited from class org.springframework.integration.ip.AbstractInternetProtocolSendingMessageHandler
destinationAddress, host, logger, port, soSendBufferSize, soTimeout
 
Fields inherited from interface org.springframework.core.Ordered
HIGHEST_PRECEDENCE, LOWEST_PRECEDENCE
 
Constructor Summary
UnicastSendingMessageHandler(String host, int port)
          Basic constructor; no reliability; no acknowledgment.
UnicastSendingMessageHandler(String host, int port, boolean lengthCheck)
          Can used to add a length to each packet which can be checked at the destination.
UnicastSendingMessageHandler(String host, int port, boolean lengthCheck, boolean acknowledge, String ackHost, int ackPort, int ackTimeout)
          Add a length and/or acknowledgment request to packets.
UnicastSendingMessageHandler(String host, int port, boolean acknowledge, String ackHost, int ackPort, int ackTimeout)
          Add an acknowledgment request to packets.
 
Method Summary
protected  DatagramSocket getSocket()
           
 void handleMessageInternal(Message<?> message)
           
 void onInit()
          Subclasses may implement this for initialization logic.
 void restartAckThread()
          If exposed as an MBean, can be used to restart the ack thread if a fatal (bind) error occurred, without bouncing the JVM.
 void run()
          Process acknowledgments, if requested.
protected  void send(DatagramPacket packet)
           
 void setLocalAddress(String localAddress)
          On a multi-homed system, specifies the ip address of the network interface used to communicate.
protected  void setReliabilityAttributes(boolean lengthCheck, boolean acknowledge, String ackHost, int ackPort, int ackTimeout)
           
protected  void setSocketAttributes(DatagramSocket socket)
           
 void setSoReceiveBufferSize(int size)
           
 void setTaskExecutor(Executor taskExecutor)
           
 void shutDown()
           
 
Methods inherited from class org.springframework.integration.ip.AbstractInternetProtocolSendingMessageHandler
getPort, setSoSendBufferSize, setSoTimeout
 
Methods inherited from class org.springframework.integration.handler.AbstractMessageHandler
getComponentType, getOrder, handleMessage, setOrder, setShouldTrack
 
Methods inherited from class org.springframework.integration.context.IntegrationObjectSupport
afterPropertiesSet, getBeanFactory, getComponentName, getConversionService, getRequiredMetadataPersister, getTaskScheduler, setBeanFactory, setBeanName, setComponentName, setConversionService, setTaskScheduler, toString
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 
Methods inherited from interface org.springframework.integration.context.NamedComponent
getComponentName
 

Field Detail

mapper

protected final DatagramPacketMessageMapper mapper

socket

protected volatile DatagramSocket socket

waitForAck

protected volatile boolean waitForAck
If true adds headers to instruct receiving adapter to return an ack.


acknowledge

protected volatile boolean acknowledge

ackPort

protected volatile int ackPort

ackTimeout

protected volatile int ackTimeout

ackCounter

protected volatile int ackCounter

ackControl

protected volatile Map<String,CountDownLatch> ackControl

fatalException

protected volatile Exception fatalException

soReceiveBufferSize

protected int soReceiveBufferSize

localAddress

protected String localAddress

taskExecutor

protected volatile Executor taskExecutor
Constructor Detail

UnicastSendingMessageHandler

public UnicastSendingMessageHandler(String host,
                                    int port)
Basic constructor; no reliability; no acknowledgment.

Parameters:
host - Destination host.
port - Destination port.

UnicastSendingMessageHandler

public UnicastSendingMessageHandler(String host,
                                    int port,
                                    boolean lengthCheck)
Can used to add a length to each packet which can be checked at the destination.

Parameters:
host - Destination Host.
port - Destination Port.
lengthCheck - If true, packets will contain a length.

UnicastSendingMessageHandler

public UnicastSendingMessageHandler(String host,
                                    int port,
                                    boolean acknowledge,
                                    String ackHost,
                                    int ackPort,
                                    int ackTimeout)
Add an acknowledgment request to packets.

Parameters:
host - Destination Host.
port - Destination Port.
acknowledge - If true, packets will request acknowledgment.
ackHost - The host to which acks should be sent. Required if ack true.
ackPort - The port to which acks should be sent.
ackTimeout - How long we will wait (milliseconds) for the ack.

UnicastSendingMessageHandler

public UnicastSendingMessageHandler(String host,
                                    int port,
                                    boolean lengthCheck,
                                    boolean acknowledge,
                                    String ackHost,
                                    int ackPort,
                                    int ackTimeout)
Add a length and/or acknowledgment request to packets.

Parameters:
host - Destination Host.
port - Destination Port.
lengthCheck - If true, packets will contain a length.
acknowledge - If true, packets will request acknowledgment.
ackHost - The host to which acks should be sent. Required if ack true.
ackPort - The port to which acks should be sent.
ackTimeout - How long we will wait (milliseconds) for the ack.
Method Detail

setReliabilityAttributes

protected void setReliabilityAttributes(boolean lengthCheck,
                                        boolean acknowledge,
                                        String ackHost,
                                        int ackPort,
                                        int ackTimeout)

onInit

public void onInit()
Description copied from class: IntegrationObjectSupport
Subclasses may implement this for initialization logic.

Overrides:
onInit in class IntegrationObjectSupport

handleMessageInternal

public void handleMessageInternal(Message<?> message)
                           throws MessageRejectedException,
                                  MessageHandlingException,
                                  MessageDeliveryException
Specified by:
handleMessageInternal in class AbstractMessageHandler
Throws:
MessageRejectedException
MessageHandlingException
MessageDeliveryException

send

protected void send(DatagramPacket packet)
             throws Exception
Throws:
Exception

getSocket

protected DatagramSocket getSocket()
                            throws IOException
Throws:
IOException

setSocketAttributes

protected void setSocketAttributes(DatagramSocket socket)
                            throws SocketException
Throws:
SocketException

run

public void run()
Process acknowledgments, if requested.

Specified by:
run in interface Runnable

restartAckThread

public void restartAckThread()
If exposed as an MBean, can be used to restart the ack thread if a fatal (bind) error occurred, without bouncing the JVM.


shutDown

public void shutDown()

setSoReceiveBufferSize

public void setSoReceiveBufferSize(int size)
Specified by:
setSoReceiveBufferSize in interface CommonSocketOptions
Overrides:
setSoReceiveBufferSize in class AbstractInternetProtocolSendingMessageHandler
See Also:
Socket.setReceiveBufferSize(int), DatagramSocket.setReceiveBufferSize(int)

setLocalAddress

public void setLocalAddress(String localAddress)
Description copied from interface: CommonSocketOptions
On a multi-homed system, specifies the ip address of the network interface used to communicate. For inbound adapters and gateways, specifies the interface used to listed for incoming connections. If omitted, the endpoint will listen on all available adapters. For the UDP multicast outbound adapter specifies the interface to which multicast packets will be sent. For UDP unicast and multicast adapters, specifies which interface to which the acknowledgment socket will be bound. Does not apply to TCP outbound adapters and gateways.

Specified by:
setLocalAddress in interface CommonSocketOptions

setTaskExecutor

public void setTaskExecutor(Executor taskExecutor)

Spring Integration

Copyright © 2010. All Rights Reserved.