JMS命名空间支持
Spring提供了一个用于简化JMS配置的XML命名空间。要使用JMS命名空间元素,您需要引用JMS模式,如下例所示:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:jms="http://www.springframework.org/schema/jms" (1)
xsi:schemaLocation="
http://www.springframework.org/schema/beans
https://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/jms
https://www.springframework.org/schema/jms/spring-jms.xsd">
<!-- bean definitions here -->
</beans>
1 | 引用JMS模式。 |
该命名空间由三个顶级元素组成:<annotation-driven/>
、<listener-container/>
和<jca-listener-container/>
。<annotation-driven/>
启用了基于注解的监听器端点的使用。<listener-container/>
和<jca-listener-container/>
定义了共享的监听器容器配置,并可以包含<listener/>
子元素。以下示例展示了两个监听器的基本配置:
<jms:listener-container>
<jms:listener destination="queue.orders" ref="orderService" method="placeOrder"/>
<jms:listener destination="queue.confirmations" ref="confirmationLogger" method="log"/>
</jms:listener-container>
上述示例等同于创建两个不同的监听器容器bean定义和两个不同的MessageListenerAdapter
bean定义,如使用MessageListenerAdapter
中所示。除了前面示例中显示的属性外,listener
元素还可以包含几个可选属性。以下表格描述了所有可用属性:
属性 | 描述 |
---|---|
|
托管监听器容器的bean名称。如果未指定,将自动生成一个bean名称。 |
|
此监听器的目的地名称,通过 |
|
处理程序对象的bean名称。 |
|
要调用的处理程序方法的名称。如果 |
|
默认响应目的地的名称,用于发送响应消息。在请求消息不携带 |
|
持久订阅的名称(如果有)。 |
|
此监听器的可选消息选择器。 |
|
要为此监听器启动的并发会话或消费者数。此值可以是表示最大数量的简单数字(例如, |
<listener-container/>
元素还接受几个可选属性。这允许自定义各种策略(例如,taskExecutor
和destinationResolver
)以及基本的JMS设置和资源引用。通过使用这些属性,您可以定义高度定制的监听器容器,同时仍然从命名空间的便利性中受益。
通过指定要通过factory-id
属性公开的bean的id
,您可以自动将这些设置公开为JmsListenerContainerFactory
,如下例所示:
<jms:listener-container connection-factory="myConnectionFactory"
task-executor="myTaskExecutor"
destination-resolver="myDestinationResolver"
transaction-manager="myTransactionManager"
concurrency="10">
<jms:listener destination="queue.orders" ref="orderService" method="placeOrder"/>
<jms:listener destination="queue.confirmations" ref="confirmationLogger" method="log"/>
</jms:listener-container>
以下表格描述了所有可用属性。有关各个属性的详细信息,请参阅AbstractMessageListenerContainer
及其具体子类的类级别javadoc。javadoc还提供了有关事务选择和消息重传方案的讨论。
属性 | 描述 |
---|---|
|
此监听器容器的类型。可用选项为 |
|
作为完全限定类名的自定义监听器容器实现类。默认为Spring的标准 |
|
将此元素定义的设置公开为具有指定 |
|
对 JMS |
|
对用于 JMS 监听器调用者的 Spring |
|
用于解析 JMS |
|
用于将 JMS 消息转换为监听器方法参数的 |
|
用于处理在执行 |
|
此监听器的 JMS 目标类型: |
|
响应的 JMS 目标类型: |
|
此监听器容器的 JMS 客户端 ID。在使用持久订阅时必须指定。 |
|
JMS 资源的缓存级别: |
|
本机 JMS 确认模式: |
|
对外部 |
|
为每个监听器启动的并发会话或消费者数量。它可以是一个简单的数字,表示最大数量(例如, |
|
加载到单个会话中的最大消息数。请注意,提高此数字可能导致并发消费者饥饿。 |
|
用于接收调用的超时时间(以毫秒为单位)。默认为 |
|
指定用于计算恢复尝试之间间隔的 |
|
恢复尝试之间的间隔,以毫秒为单位。它提供了一种方便的方式来创建具有指定间隔的 |
|
此容器应启动和停止的生命周期阶段。值越低,容器启动得越早,停止得越晚。默认为 |
使用 jms
模式支持的基于 JCA 的监听器容器配置非常类似,如下例所示:
<jms:jca-listener-container resource-adapter="myResourceAdapter"
destination-resolver="myDestinationResolver"
transaction-manager="myTransactionManager"
concurrency="10">
<jms:listener destination="queue.orders" ref="myMessageListener"/>
</jms:jca-listener-container>
以下表格描述了 JCA 变体的可用配置选项:
属性 | 描述 |
---|---|
|
将此元素定义的设置公开为具有指定 |
|
引用 JCA |
|
引用 |
|
引用用于解析 JMS |
|
引用用于将 JMS 消息转换为监听器方法参数的 |
|
此监听器的 JMS 目标类型: |
|
响应的 JMS 目标类型: |
|
此监听器容器的 JMS 客户端 ID。在使用持久订阅时需要指定。 |
|
本机 JMS 确认模式: |
|
引用 Spring 的 |
|
每个监听器启动的并发会话或消费者数量。可以是表示最大数量的简单数字(例如 |
|
加载到单个会话中的最大消息数。请注意,提高此数字可能导致并发消费者饥饿。 |