Class ActiveMQQueueSender
- All Implemented Interfaces:
jakarta.jms.MessageProducer,jakarta.jms.QueueSender,AutoCloseable,Closeable,Disposable,StatsCapable
QueueSender object to send messages to a
queue.
Normally, the Queue is specified when a QueueSender
is created. In this case, an attempt to use the send methods
for an unidentified QueueSender will throw a
java.lang.UnsupportedOperationException.
If the QueueSender is created with an unidentified
Queue,
an attempt to use the send methods that assume that the
Queue has been identified will throw a
java.lang.UnsupportedOperationException.
During the execution of its send method, a message must not be
changed by other threads within the client. If the message is modified, the
result of the send is 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,
JMSMessageID and JMSTimeStamp. When the
message is sent, the values of these headers are ignored. After the
completion of the send, the headers hold the values specified
by the method sending the message. It is possible for the send
method not to set JMSMessageID and JMSTimeStamp
if the setting of these headers is explicitly disabled by the
MessageProducer.setDisableMessageID or
MessageProducer.setDisableMessageTimestamp method.
Creating a MessageProducer provides the same features as
creating a QueueSender. A MessageProducer
object is recommended when creating new code. The QueueSender
is provided to support existing code.
- See Also:
-
MessageProducerQueueSession.createSender(Queue)
-
Field Summary
Fields inherited from class org.apache.activemq.ActiveMQMessageProducer
closed, infoFields inherited from class org.apache.activemq.ActiveMQMessageProducerSupport
defaultDeliveryMode, defaultPriority, defaultTimeToLive, disableMessageID, disableMessageTimestamp, JMS_PROPERTY_NAMES_DISALLOWED, sendTimeout, session -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedActiveMQQueueSender(ActiveMQSession session, ActiveMQDestination destination, int sendTimeout) -
Method Summary
Modifier and TypeMethodDescriptionjakarta.jms.QueuegetQueue()Gets the queue associated with thisQueueSender.voidsend(jakarta.jms.Queue queue, jakarta.jms.Message message) Sends a message to a queue for an unidentified message producer.voidsend(jakarta.jms.Queue queue, jakarta.jms.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, send, send, send, send, send, setMessageSequence, setProducerInfo, setTransformer, toStringMethods inherited from class org.apache.activemq.ActiveMQMessageProducerSupport
getDeliveryDelay, getDeliveryMode, getDisableMessageID, getDisableMessageTimestamp, getPriority, getSendTimeout, getTimeToLive, send, send, send, setDeliveryDelay, setDeliveryMode, setDisableMessageID, setDisableMessageTimestamp, setPriority, setSendTimeout, setTimeToLive, validateValidPropertyName, validateValidPropertyValueMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface jakarta.jms.MessageProducer
close, getDeliveryDelay, getDeliveryMode, getDestination, getDisableMessageID, getDisableMessageTimestamp, getPriority, getTimeToLive, send, send, send, send, send, send, setDeliveryDelay, setDeliveryMode, setDisableMessageID, setDisableMessageTimestamp, setPriority, setTimeToLiveMethods inherited from interface jakarta.jms.QueueSender
send, send
-
Constructor Details
-
ActiveMQQueueSender
protected ActiveMQQueueSender(ActiveMQSession session, ActiveMQDestination destination, int sendTimeout) throws jakarta.jms.JMSException - Throws:
jakarta.jms.JMSException
-
-
Method Details
-
getQueue
public jakarta.jms.Queue getQueue() throws jakarta.jms.JMSExceptionGets the queue associated with thisQueueSender.- Specified by:
getQueuein interfacejakarta.jms.QueueSender- Returns:
- this sender's queue
- Throws:
jakarta.jms.JMSException- if the JMS provider fails to get the queue for thisQueueSenderdue to some internal error.
-
send
public void send(jakarta.jms.Queue queue, jakarta.jms.Message message) throws jakarta.jms.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 interfacejakarta.jms.QueueSender- Parameters:
queue- the queue to send this message tomessage- the message to send- Throws:
jakarta.jms.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(jakarta.jms.Queue queue, jakarta.jms.Message message, int deliveryMode, int priority, long timeToLive) throws jakarta.jms.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 interfacejakarta.jms.QueueSender- 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:
jakarta.jms.JMSException- if the JMS provider fails to send the message due to some internal error.
-