自 1.3 以来 1.4 的变化
@RabbitListener
注解
POJO 监听器可以使用@RabbitListener
,由@EnableRabbit
或<rabbit:annotation-driven />
. 此功能需要 Spring Framework 4.1。有关更多信息,请参阅 Annotation-driven Listener Endpoints 。
RabbitMessagingTemplate
添加
一个新的RabbitMessagingTemplate
允许您通过使用spring-messaging
Message
实例。 在内部,它使用RabbitTemplate
,您可以正常配置。此功能需要 Spring Framework 4.1。有关更多信息,请参阅消息传递集成。
侦听器容器missingQueuesFatal
属性
1.3.5 引入了missingQueuesFatal
属性SimpleMessageListenerContainer
. 现在,这在侦听器容器命名空间元素上可用。请参阅消息侦听器容器配置。
兔子模板ConfirmCallback
接口
这confirm
方法有一个额外的参数,称为cause
. 如果可用,此参数包含否定确认 (nack) 的原因。请参阅相关发布者确认和返回。
RabbitConnectionFactoryBean
添加
RabbitConnectionFactoryBean
创建底层 RabbitMQConnectionFactory
由CachingConnectionFactory
. 这允许使用 Spring 的依赖注入配置 SSL 选项。请参阅配置底层客户端连接工厂。
用CachingConnectionFactory
这CachingConnectionFactory
现在让connectionTimeout
设置为命名空间中的属性或属性。它在底层 RabbitMQ 上设置属性ConnectionFactory
. 请参阅配置底层客户端连接工厂。
日志附加器
日志返回org.springframework.amqp.rabbit.logback.AmqpAppender
已被引入。它提供了类似于org.springframework.amqp.rabbit.log4j.AmqpAppender
. 有关更多信息,请参阅这些类的 JavaDoc。
日志4jAmqpAppender
现在支持deliveryMode
属性 (PERSISTENT
或NON_PERSISTENT
违约:PERSISTENT
). 以前,所有 log4j 消息都是PERSISTENT
.
附加器还支持修改Message
发送之前 — 例如,允许添加自定义标头。子类应该覆盖postProcessMessageBeforeSend()
.
侦听器队列
现在,默认情况下,侦听器容器会在启动期间重新声明任何丢失的队列。一个新的auto-declare
属性已添加到<rabbit:listener-container>
以防止这些重新声明。 看auto-delete
队列.
RabbitTemplate
:mandatory
和connectionFactorySelector
表达 式
这mandatoryExpression
,sendConnectionFactorySelectorExpression
和receiveConnectionFactorySelectorExpression
SpEL 表达式的属性已添加到RabbitTemplate
. 这mandatoryExpression
用于评估mandatory
当ReturnCallback
正在使用中。请参阅相关发布者确认和返回。 这sendConnectionFactorySelectorExpression
和receiveConnectionFactorySelectorExpression
当AbstractRoutingConnectionFactory
,以确定lookupKey
对于目标ConnectionFactory
在每个 AMQP 协议交互作的运行时。请参阅路由连接工厂。
侦听器和路由连接工厂
您可以配置SimpleMessageListenerContainer
使用路由连接工厂,以启用基于队列名称的连接选择。请参阅路由连接工厂。
RabbitTemplate
:RecoveryCallback
选择
这recoveryCallback
属性已添加,可在retryTemplate.execute()
. 请参阅添加重试功能。
MessageConversionException
改变
此异常现在是AmqpException
. 考虑以下代码:
try {
template.convertAndSend("thing1", "thing2", "cat");
}
catch (AmqpException e) {
...
}
catch (MessageConversionException e) {
...
}
第二个捕获块不再可访问,需要移动到捕获所有AmqpException
catch 块。
RabbitMQ 3.4 兼容性
Spring AMQP 现在与 RabbitMQ 3.4 兼容,包括直接回复。有关更多信息,请参阅兼容性和 RabbitMQ 直接回复。
ContentTypeDelegatingMessageConverter
添加
这ContentTypeDelegatingMessageConverter
已引入以选择MessageConverter
使用,基于contentType
属性中的MessageProperties
. 有关详细信息,请参阅消息转换器。