Class ActiveMQQueueSender
- java.lang.Object
-
- org.apache.activemq.ActiveMQMessageProducerSupport
-
- org.apache.activemq.ActiveMQMessageProducer
-
- org.apache.activemq.ActiveMQQueueSender
-
- All Implemented Interfaces:
MessageProducer,QueueSender,Closeable,Disposable,StatsCapable
public class ActiveMQQueueSender extends ActiveMQMessageProducer implements QueueSender
A client uses aQueueSenderobject to send messages to a queue.Normally, the
Queueis specified when aQueueSenderis created. In this case, an attempt to use thesendmethods for an unidentifiedQueueSenderwill throw ajava.lang.UnsupportedOperationException.If the
QueueSenderis created with an unidentifiedQueue, an attempt to use thesendmethods that assume that theQueuehas been identified will throw ajava.lang.UnsupportedOperationException.During the execution of its
sendmethod, a message must not be changed by other threads within the client. If the message is modified, the result of thesendis undefined.After sending a message, a client may retain and modify it without affecting the message that has been sent. The same message object may be sent multiple times.
The following message headers are set as part of sending a message:
JMSDestination,JMSDeliveryMode,JMSExpiration,JMSPriority,JMSMessageIDandJMSTimeStamp. When the message is sent, the values of these headers are ignored. After the completion of thesend, the headers hold the values specified by the method sending the message. It is possible for thesendmethod not to setJMSMessageIDandJMSTimeStampif the setting of these headers is explicitly disabled by theMessageProducer.setDisableMessageIDorMessageProducer.setDisableMessageTimestampmethod.Creating a
MessageProducerprovides the same features as creating aQueueSender. AMessageProducerobject is recommended when creating new code. TheQueueSenderis provided to support existing code.- See Also:
MessageProducer,QueueSession.createSender(Queue)
-
-
Field Summary
-
Fields inherited from class org.apache.activemq.ActiveMQMessageProducer
closed, info
-
Fields inherited from class org.apache.activemq.ActiveMQMessageProducerSupport
defaultDeliveryMode, defaultPriority, defaultTimeToLive, disableMessageID, disableMessageTimestamp, sendTimeout, session
-
-
Constructor Summary
Constructors Modifier Constructor Description protectedActiveMQQueueSender(ActiveMQSession session, ActiveMQDestination destination, int sendTimeout)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description QueuegetQueue()Gets the queue associated with thisQueueSender.voidsend(Queue queue, Message message)Sends a message to a queue for an unidentified message producer.voidsend(Queue queue, Message message, int deliveryMode, int priority, long timeToLive)Sends a message to a queue for an unidentified message producer, specifying delivery mode, priority and time to live.-
Methods inherited from class org.apache.activemq.ActiveMQMessageProducer
checkClosed, close, dispose, getDestination, getMessageSequence, getProducerInfo, getProducerStats, getStartTime, getStats, getTransformer, onProducerAck, send, send, send, send, send, setMessageSequence, setProducerInfo, setTransformer, toString
-
Methods inherited from class org.apache.activemq.ActiveMQMessageProducerSupport
getDeliveryMode, getDisableMessageID, getDisableMessageTimestamp, getPriority, getSendTimeout, getTimeToLive, send, send, send, setDeliveryMode, setDisableMessageID, setDisableMessageTimestamp, setPriority, setSendTimeout, setTimeToLive
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface javax.jms.MessageProducer
close, getDeliveryMode, getDestination, getDisableMessageID, getDisableMessageTimestamp, getPriority, getTimeToLive, send, send, setDeliveryMode, setDisableMessageID, setDisableMessageTimestamp, setPriority, setTimeToLive
-
Methods inherited from interface javax.jms.QueueSender
send, send
-
-
-
-
Constructor Detail
-
ActiveMQQueueSender
protected ActiveMQQueueSender(ActiveMQSession session, ActiveMQDestination destination, int sendTimeout) throws JMSException
- Throws:
JMSException
-
-
Method Detail
-
getQueue
public Queue getQueue() throws JMSException
Gets the queue associated with thisQueueSender.- Specified by:
getQueuein interfaceQueueSender- Returns:
- this sender's queue
- Throws:
JMSException- if the JMS provider fails to get the queue for thisQueueSenderdue to some internal error.
-
send
public void send(Queue queue, Message message) throws JMSException
Sends a message to a queue for an unidentified message producer. Uses theQueueSender's default delivery mode, priority, and time to live.Typically, a message producer is assigned a queue at creation time; however, the JMS API also supports unidentified message producers, which require that the queue be supplied every time a message is sent.
- Specified by:
sendin interfaceQueueSender- Parameters:
queue- the queue to send this message tomessage- the message to send- Throws:
JMSException- if the JMS provider fails to send the message due to some internal error.- See Also:
MessageProducer.getDeliveryMode(),MessageProducer.getTimeToLive(),MessageProducer.getPriority()
-
send
public void send(Queue queue, Message message, int deliveryMode, int priority, long timeToLive) throws JMSException
Sends a message to a queue for an unidentified message producer, specifying delivery mode, priority and time to live.Typically, a message producer is assigned a queue at creation time; however, the JMS API also supports unidentified message producers, which require that the queue be supplied every time a message is sent.
- Specified by:
sendin interfaceQueueSender- Parameters:
queue- the queue to send this message tomessage- the message to senddeliveryMode- the delivery mode to usepriority- the priority for this messagetimeToLive- the message's lifetime (in milliseconds)- Throws:
JMSException- if the JMS provider fails to send the message due to some internal error.
-
-