Class AsyncRabbitTemplate
- java.lang.Object
- 
- org.springframework.amqp.rabbit.AsyncRabbitTemplate
 
- 
- All Implemented Interfaces:
- AsyncAmqpTemplate,- MessageListener,- RabbitTemplate.ConfirmCallback,- RabbitTemplate.ReturnCallback,- RabbitTemplate.ReturnsCallback,- ChannelAwareMessageListener,- Aware,- BeanNameAware,- Lifecycle,- Phased,- SmartLifecycle
 
 public class AsyncRabbitTemplate extends Object implements AsyncAmqpTemplate, ChannelAwareMessageListener, RabbitTemplate.ReturnsCallback, RabbitTemplate.ConfirmCallback, BeanNameAware, SmartLifecycle Provides asynchronous send and receive operations returning aListenableFutureallowing the caller to obtain the reply later, usingget()or a callback.When confirms are enabled, the future has a confirm property which is itself a ListenableFuture. If the reply is received before the publisher confirm, the confirm is discarded since the reply implicitly indicates the message was published.Returned (undeliverable) request messages are presented as a AmqpMessageReturnedExceptioncause of anExecutionException.Internally, the template uses a RabbitTemplateand anAbstractMessageListenerContainereither provided or constructed internally (aSimpleMessageListenerContainer). If an externalRabbitTemplateis provided and confirms/returns are enabled, it must not previously have had callbacks registered because this object needs to be the callback.- Since:
- 1.6
- Author:
- Gary Russell, Artem Bilan
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description classAsyncRabbitTemplate.RabbitConverterFuture<C>AAsyncRabbitTemplate.RabbitFuturewith a return type of the template's generic parameter.classAsyncRabbitTemplate.RabbitFuture<T>Base class forListenableFutures returned byAsyncRabbitTemplate.classAsyncRabbitTemplate.RabbitMessageFutureAAsyncRabbitTemplate.RabbitFuturewith a return type ofMessage.
 - 
Field SummaryFields Modifier and Type Field Description static intDEFAULT_RECEIVE_TIMEOUT- 
Fields inherited from interface org.springframework.context.SmartLifecycleDEFAULT_PHASE
 
- 
 - 
Constructor SummaryConstructors Constructor Description AsyncRabbitTemplate(ConnectionFactory connectionFactory, String exchange, String routingKey)Construct an instance using the provided arguments.AsyncRabbitTemplate(ConnectionFactory connectionFactory, String exchange, String routingKey, String replyQueue)Construct an instance using the provided arguments.AsyncRabbitTemplate(ConnectionFactory connectionFactory, String exchange, String routingKey, String replyQueue, String replyAddress)Construct an instance using the provided arguments.AsyncRabbitTemplate(RabbitTemplate template)Construct an instance using the provided arguments.AsyncRabbitTemplate(RabbitTemplate template, AbstractMessageListenerContainer container)Construct an instance using the provided arguments.AsyncRabbitTemplate(RabbitTemplate template, AbstractMessageListenerContainer container, String replyAddress)Construct an instance using the provided arguments.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidconfirm(CorrelationData correlationData, boolean ack, String cause)Confirmation callback.<C> AsyncRabbitTemplate.RabbitConverterFuture<C>convertSendAndReceive(Object object)Convert the object to a message and send it to the default exchange with the default routing key.<C> AsyncRabbitTemplate.RabbitConverterFuture<C>convertSendAndReceive(Object object, MessagePostProcessor messagePostProcessor)Convert the object to a message and send it to the default exchange with the default routing key after invoking theMessagePostProcessor.<C> AsyncRabbitTemplate.RabbitConverterFuture<C>convertSendAndReceive(String routingKey, Object object)Convert the object to a message and send it to the default exchange with the provided routing key.<C> AsyncRabbitTemplate.RabbitConverterFuture<C>convertSendAndReceive(String routingKey, Object object, MessagePostProcessor messagePostProcessor)Convert the object to a message and send it to the default exchange with the provided routing key after invoking theMessagePostProcessor.<C> AsyncRabbitTemplate.RabbitConverterFuture<C>convertSendAndReceive(String exchange, String routingKey, Object object)Convert the object to a message and send it to the provided exchange and routing key.<C> AsyncRabbitTemplate.RabbitConverterFuture<C>convertSendAndReceive(String exchange, String routingKey, Object object, MessagePostProcessor messagePostProcessor)Convert the object to a message and send it to the provided exchange and routing key after invoking theMessagePostProcessor.<C> AsyncRabbitTemplate.RabbitConverterFuture<C>convertSendAndReceiveAsType(Object object, MessagePostProcessor messagePostProcessor, ParameterizedTypeReference<C> responseType)Convert the object to a message and send it to the default exchange with the default routing key after invoking theMessagePostProcessor.<C> AsyncRabbitTemplate.RabbitConverterFuture<C>convertSendAndReceiveAsType(Object object, ParameterizedTypeReference<C> responseType)Convert the object to a message and send it to the default exchange with the default routing key.<C> AsyncRabbitTemplate.RabbitConverterFuture<C>convertSendAndReceiveAsType(String routingKey, Object object, MessagePostProcessor messagePostProcessor, ParameterizedTypeReference<C> responseType)Convert the object to a message and send it to the default exchange with the provided routing key after invoking theMessagePostProcessor.<C> AsyncRabbitTemplate.RabbitConverterFuture<C>convertSendAndReceiveAsType(String routingKey, Object object, ParameterizedTypeReference<C> responseType)Convert the object to a message and send it to the default exchange with the provided routing key.<C> AsyncRabbitTemplate.RabbitConverterFuture<C>convertSendAndReceiveAsType(String exchange, String routingKey, Object object, MessagePostProcessor messagePostProcessor, ParameterizedTypeReference<C> responseType)Convert the object to a message and send it to the provided exchange and routing key after invoking theMessagePostProcessor.<C> AsyncRabbitTemplate.RabbitConverterFuture<C>convertSendAndReceiveAsType(String exchange, String routingKey, Object object, ParameterizedTypeReference<C> responseType)Convert the object to a message and send it to the provided exchange and routing key.StringgetBeanName()ConnectionFactorygetConnectionFactory()MessageConvertergetMessageConverter()intgetPhase()RabbitTemplategetRabbitTemplate()Return the underlyingRabbitTemplateused for sending.booleanisAutoStartup()booleanisRunning()voidonMessage(Message message, com.rabbitmq.client.Channel channel)Callback for processing a received Rabbit message.voidreturnedMessage(ReturnedMessage returned)Returned message callback.AsyncRabbitTemplate.RabbitMessageFuturesendAndReceive(String exchange, String routingKey, Message message)Send a message to the supplied exchange and routing key.AsyncRabbitTemplate.RabbitMessageFuturesendAndReceive(String routingKey, Message message)Send a message to the default exchange with the supplied routing key.AsyncRabbitTemplate.RabbitMessageFuturesendAndReceive(Message message)Send a message to the default exchange with the default routing key.voidsetAutoStartup(boolean autoStartup)voidsetBeanName(String beanName)voidsetEnableConfirms(boolean enableConfirms)Set to true to enable publisher confirms.voidsetMandatory(boolean mandatory)Set to true to enable the receipt of returned messages that cannot be delivered in the form of aAmqpMessageReturnedException.voidsetMandatoryExpression(Expression mandatoryExpression)voidsetMandatoryExpressionString(String mandatoryExpression)voidsetPhase(int phase)voidsetReceiveTimeout(long receiveTimeout)Set the receive timeout - the future returned by the send and receive methods will be canceled when this timeout expires.voidsetTaskScheduler(TaskScheduler taskScheduler)Set the task scheduler to expire timed out futures.voidstart()voidstop()StringtoString()- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface org.springframework.amqp.rabbit.listener.api.ChannelAwareMessageListeneronMessage, onMessageBatch
 - 
Methods inherited from interface org.springframework.amqp.core.MessageListenercontainerAckMode, isAsyncReplies, onMessageBatch
 - 
Methods inherited from interface org.springframework.amqp.rabbit.core.RabbitTemplate.ReturnsCallbackdelegate, returnedMessage
 - 
Methods inherited from interface org.springframework.context.SmartLifecyclestop
 
- 
 
- 
- 
- 
Field Detail- 
DEFAULT_RECEIVE_TIMEOUTpublic static final int DEFAULT_RECEIVE_TIMEOUT - See Also:
- Constant Field Values
 
 
- 
 - 
Constructor Detail- 
AsyncRabbitTemplatepublic AsyncRabbitTemplate(ConnectionFactory connectionFactory, String exchange, String routingKey, String replyQueue) Construct an instance using the provided arguments. Replies will be routed to the default exchange using the reply queue name as the routing key.- Parameters:
- connectionFactory- the connection factory.
- exchange- the default exchange to which requests will be sent.
- routingKey- the default routing key.
- replyQueue- the name of the reply queue to listen for replies.
 
 - 
AsyncRabbitTemplatepublic AsyncRabbitTemplate(ConnectionFactory connectionFactory, String exchange, String routingKey, String replyQueue, String replyAddress) Construct an instance using the provided arguments. If 'replyAddress' is null, replies will be routed to the default exchange using the reply queue name as the routing key. Otherwise it should have the form exchange/routingKey and must cause messages to be routed to the reply queue.- Parameters:
- connectionFactory- the connection factory.
- exchange- the default exchange to which requests will be sent.
- routingKey- the default routing key.
- replyQueue- the name of the reply queue to listen for replies.
- replyAddress- the reply address (exchange/routingKey).
 
 - 
AsyncRabbitTemplatepublic AsyncRabbitTemplate(RabbitTemplate template, AbstractMessageListenerContainer container) Construct an instance using the provided arguments. The first queue the container is configured to listen to will be used as the reply queue. Replies will be routed using the default exchange with that queue name as the routing key.- Parameters:
- template- a- RabbitTemplate
- container- a- AbstractMessageListenerContainer.
 
 - 
AsyncRabbitTemplatepublic AsyncRabbitTemplate(RabbitTemplate template, AbstractMessageListenerContainer container, String replyAddress) Construct an instance using the provided arguments. The first queue the container is configured to listen to will be used as the reply queue. If 'replyAddress' is null, replies will be routed using the default exchange with that queue name as the routing key. Otherwise it should have the form exchange/routingKey and must cause messages to be routed to the reply queue.- Parameters:
- template- a- RabbitTemplate.
- container- a- AbstractMessageListenerContainer.
- replyAddress- the reply address.
 
 - 
AsyncRabbitTemplatepublic AsyncRabbitTemplate(ConnectionFactory connectionFactory, String exchange, String routingKey) Construct an instance using the provided arguments. "Direct replyTo" is used for replies.- Parameters:
- connectionFactory- the connection factory.
- exchange- the default exchange to which requests will be sent.
- routingKey- the default routing key.
- Since:
- 2.0
 
 - 
AsyncRabbitTemplatepublic AsyncRabbitTemplate(RabbitTemplate template) Construct an instance using the provided arguments. "Direct replyTo" is used for replies.- Parameters:
- template- a- RabbitTemplate
- Since:
- 2.0
 
 
- 
 - 
Method Detail- 
setAutoStartuppublic void setAutoStartup(boolean autoStartup) - Parameters:
- autoStartup- true for auto start.
- See Also:
- isAutoStartup()
 
 - 
setPhasepublic void setPhase(int phase) - Parameters:
- phase- the phase.
- See Also:
- getPhase()
 
 - 
setMandatorypublic void setMandatory(boolean mandatory) Set to true to enable the receipt of returned messages that cannot be delivered in the form of aAmqpMessageReturnedException.- Parameters:
- mandatory- true to enable returns.
 
 - 
setMandatoryExpressionpublic void setMandatoryExpression(Expression mandatoryExpression) - Parameters:
- mandatoryExpression- a SpEL- Expressionto evaluate against each request message. The result of the evaluation must be a- booleanvalue.
- Since:
- 2.0
 
 - 
setMandatoryExpressionStringpublic void setMandatoryExpressionString(String mandatoryExpression) - Parameters:
- mandatoryExpression- a SpEL- Expressionto evaluate against each request message. The result of the evaluation must be a- booleanvalue.
- Since:
- 2.0
 
 - 
setEnableConfirmspublic void setEnableConfirms(boolean enableConfirms) Set to true to enable publisher confirms. When enabled, theAsyncRabbitTemplate.RabbitFuturereturned by the send and receive operation will have aListenableFuture<Boolean>in itsconfirmproperty.- Parameters:
- enableConfirms- true to enable publisher confirms.
 
 - 
getBeanNamepublic String getBeanName() 
 - 
setBeanNamepublic void setBeanName(String beanName) - Specified by:
- setBeanNamein interface- BeanNameAware
 
 - 
getConnectionFactorypublic ConnectionFactory getConnectionFactory() - Returns:
- a reference to the underlying connection factory in the
 RabbitTemplate.
 
 - 
setReceiveTimeoutpublic void setReceiveTimeout(long receiveTimeout) Set the receive timeout - the future returned by the send and receive methods will be canceled when this timeout expires.<= 0means futures never expire. Beware that this will cause a memory leak if a reply is not received. Default: 30000 (30 seconds).- Parameters:
- receiveTimeout- the timeout in milliseconds.
 
 - 
setTaskSchedulerpublic void setTaskScheduler(TaskScheduler taskScheduler) Set the task scheduler to expire timed out futures.- Parameters:
- taskScheduler- the task scheduler
- See Also:
- setReceiveTimeout(long)
 
 - 
getMessageConverterpublic MessageConverter getMessageConverter() - Returns:
- a reference to the underlying RabbitTemplate'sMessageConverter.
 
 - 
getRabbitTemplatepublic RabbitTemplate getRabbitTemplate() Return the underlyingRabbitTemplateused for sending.- Returns:
- the template.
- Since:
- 2.2
 
 - 
sendAndReceivepublic AsyncRabbitTemplate.RabbitMessageFuture sendAndReceive(Message message) Description copied from interface:AsyncAmqpTemplateSend a message to the default exchange with the default routing key. If the message contains a correlationId property, it must be unique.- Specified by:
- sendAndReceivein interface- AsyncAmqpTemplate
- Parameters:
- message- the message.
- Returns:
- the ListenableFuture.
 
 - 
sendAndReceivepublic AsyncRabbitTemplate.RabbitMessageFuture sendAndReceive(String routingKey, Message message) Description copied from interface:AsyncAmqpTemplateSend a message to the default exchange with the supplied routing key. If the message contains a correlationId property, it must be unique.- Specified by:
- sendAndReceivein interface- AsyncAmqpTemplate
- Parameters:
- routingKey- the routing key.
- message- the message.
- Returns:
- the ListenableFuture.
 
 - 
sendAndReceivepublic AsyncRabbitTemplate.RabbitMessageFuture sendAndReceive(String exchange, String routingKey, Message message) Description copied from interface:AsyncAmqpTemplateSend a message to the supplied exchange and routing key. If the message contains a correlationId property, it must be unique.- Specified by:
- sendAndReceivein interface- AsyncAmqpTemplate
- Parameters:
- exchange- the exchange.
- routingKey- the routing key.
- message- the message.
- Returns:
- the ListenableFuture.
 
 - 
convertSendAndReceivepublic <C> AsyncRabbitTemplate.RabbitConverterFuture<C> convertSendAndReceive(Object object) Description copied from interface:AsyncAmqpTemplateConvert the object to a message and send it to the default exchange with the default routing key.- Specified by:
- convertSendAndReceivein interface- AsyncAmqpTemplate
- Type Parameters:
- C- the expected result type.
- Parameters:
- object- the object to convert.
- Returns:
- the ListenableFuture.
 
 - 
convertSendAndReceivepublic <C> AsyncRabbitTemplate.RabbitConverterFuture<C> convertSendAndReceive(String routingKey, Object object) Description copied from interface:AsyncAmqpTemplateConvert the object to a message and send it to the default exchange with the provided routing key.- Specified by:
- convertSendAndReceivein interface- AsyncAmqpTemplate
- Type Parameters:
- C- the expected result type.
- Parameters:
- routingKey- the routing key.
- object- the object to convert.
- Returns:
- the ListenableFuture.
 
 - 
convertSendAndReceivepublic <C> AsyncRabbitTemplate.RabbitConverterFuture<C> convertSendAndReceive(String exchange, String routingKey, Object object) Description copied from interface:AsyncAmqpTemplateConvert the object to a message and send it to the provided exchange and routing key.- Specified by:
- convertSendAndReceivein interface- AsyncAmqpTemplate
- Type Parameters:
- C- the expected result type.
- Parameters:
- exchange- the exchange.
- routingKey- the routing key.
- object- the object to convert.
- Returns:
- the ListenableFuture.
 
 - 
convertSendAndReceivepublic <C> AsyncRabbitTemplate.RabbitConverterFuture<C> convertSendAndReceive(Object object, MessagePostProcessor messagePostProcessor) Description copied from interface:AsyncAmqpTemplateConvert the object to a message and send it to the default exchange with the default routing key after invoking theMessagePostProcessor. If the post processor adds a correlationId property, it must be unique.- Specified by:
- convertSendAndReceivein interface- AsyncAmqpTemplate
- Type Parameters:
- C- the expected result type.
- Parameters:
- object- the object to convert.
- messagePostProcessor- the post processor.
- Returns:
- the ListenableFuture.
 
 - 
convertSendAndReceivepublic <C> AsyncRabbitTemplate.RabbitConverterFuture<C> convertSendAndReceive(String routingKey, Object object, MessagePostProcessor messagePostProcessor) Description copied from interface:AsyncAmqpTemplateConvert the object to a message and send it to the default exchange with the provided routing key after invoking theMessagePostProcessor. If the post processor adds a correlationId property, it must be unique.- Specified by:
- convertSendAndReceivein interface- AsyncAmqpTemplate
- Type Parameters:
- C- the expected result type.
- Parameters:
- routingKey- the routing key.
- object- the object to convert.
- messagePostProcessor- the post processor.
- Returns:
- the ListenableFuture.
 
 - 
convertSendAndReceivepublic <C> AsyncRabbitTemplate.RabbitConverterFuture<C> convertSendAndReceive(String exchange, String routingKey, Object object, MessagePostProcessor messagePostProcessor) Description copied from interface:AsyncAmqpTemplateConvert the object to a message and send it to the provided exchange and routing key after invoking theMessagePostProcessor. If the post processor adds a correlationId property, it must be unique.- Specified by:
- convertSendAndReceivein interface- AsyncAmqpTemplate
- Type Parameters:
- C- the expected result type.
- Parameters:
- exchange- the exchange
- routingKey- the routing key.
- object- the object to convert.
- messagePostProcessor- the post processor.
- Returns:
- the ListenableFuture.
 
 - 
convertSendAndReceiveAsTypepublic <C> AsyncRabbitTemplate.RabbitConverterFuture<C> convertSendAndReceiveAsType(Object object, ParameterizedTypeReference<C> responseType) Description copied from interface:AsyncAmqpTemplateConvert the object to a message and send it to the default exchange with the default routing key.- Specified by:
- convertSendAndReceiveAsTypein interface- AsyncAmqpTemplate
- Type Parameters:
- C- the expected result type.
- Parameters:
- object- the object to convert.
- responseType- the response type.
- Returns:
- the ListenableFuture.
 
 - 
convertSendAndReceiveAsTypepublic <C> AsyncRabbitTemplate.RabbitConverterFuture<C> convertSendAndReceiveAsType(String routingKey, Object object, ParameterizedTypeReference<C> responseType) Description copied from interface:AsyncAmqpTemplateConvert the object to a message and send it to the default exchange with the provided routing key.- Specified by:
- convertSendAndReceiveAsTypein interface- AsyncAmqpTemplate
- Type Parameters:
- C- the expected result type.
- Parameters:
- routingKey- the routing key.
- object- the object to convert.
- responseType- the response type.
- Returns:
- the ListenableFuture.
 
 - 
convertSendAndReceiveAsTypepublic <C> AsyncRabbitTemplate.RabbitConverterFuture<C> convertSendAndReceiveAsType(String exchange, String routingKey, Object object, ParameterizedTypeReference<C> responseType) Description copied from interface:AsyncAmqpTemplateConvert the object to a message and send it to the provided exchange and routing key.- Specified by:
- convertSendAndReceiveAsTypein interface- AsyncAmqpTemplate
- Type Parameters:
- C- the expected result type.
- Parameters:
- exchange- the exchange.
- routingKey- the routing key.
- object- the object to convert.
- responseType- the response type.
- Returns:
- the ListenableFuture.
 
 - 
convertSendAndReceiveAsTypepublic <C> AsyncRabbitTemplate.RabbitConverterFuture<C> convertSendAndReceiveAsType(Object object, MessagePostProcessor messagePostProcessor, ParameterizedTypeReference<C> responseType) Description copied from interface:AsyncAmqpTemplateConvert the object to a message and send it to the default exchange with the default routing key after invoking theMessagePostProcessor. If the post processor adds a correlationId property, it must be unique.- Specified by:
- convertSendAndReceiveAsTypein interface- AsyncAmqpTemplate
- Type Parameters:
- C- the expected result type.
- Parameters:
- object- the object to convert.
- messagePostProcessor- the post processor.
- responseType- the response type.
- Returns:
- the ListenableFuture.
 
 - 
convertSendAndReceiveAsTypepublic <C> AsyncRabbitTemplate.RabbitConverterFuture<C> convertSendAndReceiveAsType(String routingKey, Object object, MessagePostProcessor messagePostProcessor, ParameterizedTypeReference<C> responseType) Description copied from interface:AsyncAmqpTemplateConvert the object to a message and send it to the default exchange with the provided routing key after invoking theMessagePostProcessor. If the post processor adds a correlationId property, it must be unique.- Specified by:
- convertSendAndReceiveAsTypein interface- AsyncAmqpTemplate
- Type Parameters:
- C- the expected result type.
- Parameters:
- routingKey- the routing key.
- object- the object to convert.
- messagePostProcessor- the post processor.
- responseType- the response type.
- Returns:
- the ListenableFuture.
 
 - 
convertSendAndReceiveAsTypepublic <C> AsyncRabbitTemplate.RabbitConverterFuture<C> convertSendAndReceiveAsType(String exchange, String routingKey, Object object, MessagePostProcessor messagePostProcessor, ParameterizedTypeReference<C> responseType) Description copied from interface:AsyncAmqpTemplateConvert the object to a message and send it to the provided exchange and routing key after invoking theMessagePostProcessor. If the post processor adds a correlationId property, it must be unique.- Specified by:
- convertSendAndReceiveAsTypein interface- AsyncAmqpTemplate
- Type Parameters:
- C- the expected result type.
- Parameters:
- exchange- the exchange
- routingKey- the routing key.
- object- the object to convert.
- messagePostProcessor- the post processor.
- responseType- the response type.
- Returns:
- the ListenableFuture.
 
 - 
getPhasepublic int getPhase() - Specified by:
- getPhasein interface- Phased
- Specified by:
- getPhasein interface- SmartLifecycle
 
 - 
isAutoStartuppublic boolean isAutoStartup() - Specified by:
- isAutoStartupin interface- SmartLifecycle
 
 - 
onMessagepublic void onMessage(Message message, com.rabbitmq.client.Channel channel) Description copied from interface:ChannelAwareMessageListenerCallback for processing a received Rabbit message.Implementors are supposed to process the given Message, typically sending reply messages through the given Session. - Specified by:
- onMessagein interface- ChannelAwareMessageListener
- Parameters:
- message- the received AMQP message (never- null)
- channel- the underlying Rabbit Channel (never- nullunless called by the stream listener container).
 
 - 
returnedMessagepublic void returnedMessage(ReturnedMessage returned) Description copied from interface:RabbitTemplate.ReturnsCallbackReturned message callback.- Specified by:
- returnedMessagein interface- RabbitTemplate.ReturnCallback
- Specified by:
- returnedMessagein interface- RabbitTemplate.ReturnsCallback
- Parameters:
- returned- the returned message and metadata.
 
 - 
confirmpublic void confirm(@NonNull CorrelationData correlationData, boolean ack, @Nullable String cause) Description copied from interface:RabbitTemplate.ConfirmCallbackConfirmation callback.- Specified by:
- confirmin interface- RabbitTemplate.ConfirmCallback
- Parameters:
- correlationData- correlation data for the callback.
- ack- true for ack, false for nack
- cause- An optional cause, for nack, when available, otherwise null.
 
 
- 
 
-