【发布时间】:2015-03-12 23:37:32
【问题描述】:
我必须修复从另一家公司继承的应用程序,我有一个我不清楚的错误:jms 侦听器突然停止工作,没有任何明显的原因。
这是一个基于spring的客户端,这里是上下文:
<bean id="amqConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory" >
<property name="useAsyncSend" value="false" />
<property name="useCompression" value="true" />
<property name="optimizeAcknowledge" value="true" />
<property name="messagePrioritySupported" value="true" />
<property name="brokerURL" value="failover:(tcp://${brokerHost}:61616)?timeout=3000&jms.redeliveryPolicy.maximumRedeliveries=-1&jms.redeliveryPolicy.maximumRedeliveryDelay=1000000&jms.redeliveryPolicy.useExponentialBackOff=true" />
<property name="maxThreadPoolSize" value="60" />
<property name="closeTimeout" value="2000" />
<property name="nonBlockingRedelivery" value="true" />
<property name="exclusiveConsumer" value="false" />
</bean>
<bean id="jmsConnectionFactory" class="org.apache.activemq.pool.PooledConnectionFactory" >
<property name="connectionFactory" ref="amqConnectionFactory" />
<property name="maxConnections" value="50" />
<property name="maximumActiveSessionPerConnection" value="100" />
<property name="idleTimeout" value="20000" />
<property name="expiryTimeout" value="15000" />
</bean>
<bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate" abstract="true">
<property name="connectionFactory" ref="jmsConnectionFactory"/>
<property name="explicitQosEnabled" value="true"/>
<property name="sessionTransacted" value="true" />
<property name="sessionAcknowledgeModeName" value="CLIENT_ACKNOWLEDGE" />
<property name="receiveTimeout" value="4000" />
</bean>
<bean id="actionsJmsTemplate" parent="jmsTemplate">
<property name="defaultDestination" ref="actionPendingDestination"/>
</bean>
<bean id="jmsActionsListenerContainer" class="org.springframework.jms.listener.DefaultMessageListenerContainer">
<property name="connectionFactory" ref="jmsConnectionFactory"/>
<property name="destination" ref="actionPendingDestination"/>
<property name="messageSelector" value="" />
<property name="messageListener" ref="actionsListener" />
<property name="sessionTransacted" value="true"/>
<property name="cacheLevelName" value="CACHE_SESSION" />
<property name="maxConcurrentConsumers" value="50" />
<!-- <property name="transactionManager" ref="transactionManager" /> -->
<property name="transactionTimeout" value="1000" />
</bean>
<!-- ActiveMQ Destinations -->
<bean id="actionPendingDestination" class="org.apache.activemq.command.ActiveMQQueue">
<constructor-arg index="0" value="actions.pending.queue.>"/>
处理应用程序内部消息的 bean“actionsListener”实现了 javax.jms.MessageListener 和 org.springframework.beans.factory.BeanNameAware。它不会做任何事情,比如确认会话或管理事务。那个类中没有这样的代码。
库的版本是:
- 春季:3.2.5.RELEASE
- ActiveMQ 客户端:5.9
- JDK:1.6
你觉得这个配置有什么问题吗?
谢谢!
卡洛斯
【问题讨论】:
-
在停止工作之前处理了多少条消息?