无法刷新JMS连接的目的地“队列:// inventorydsDestination” - 在5000毫秒重试。原因:AOP配置似乎无效

问题描述 投票:2回答:2

我发现了以下情况例外,当我重新部署在Tomcat管理应用程序的战争。例如,在第一次部署它连接到外部的ActiveMQ正常,但是当我停止/启动Tomcat管理的战争,那么下面execption反复抛出。在此之后,JMS不与下面的异常连接到的ActiveMQ:

[2015-09-13T04:03:33.689] | [ERROR] | [inventorydsRequestListenerContainer-1] | [Could not refresh JMS Connection for destination 'queue://inventorydsDestination' - retrying in 5000 ms. Cause: AOP configuration seems to be invalid: tried calling method [public abstract javax.jms.Connection javax.jms.ConnectionFactory.createConnection() throws javax.jms.JMSException] on target [org.springframework.jms.connection.UserCredentialsConnectionFactoryAdapter@168d95c7]; nested exception is java.lang.IllegalArgumentException: java.lang.ClassCastException@2fb6f3c3]

的applicationContext-jms.xml文件

<bean id="jmsJndiConnectionFactory" class="org.springframework.jndi.JndiObjectFactoryBean">
   <property name="jndiName" value="${inventory.mq.name}"/>
   <property name="lookupOnStartup" value="false"/>
   <property name="cache" value="true" />
   <property name="proxyInterface"  value="javax.jms.QueueConnectionFactory" />
</bean>

<bean id="jmsConnectionFactory" class="org.springframework.jms.connection.CachingConnectionFactory">
    <property name="targetConnectionFactory" ref="jmsJndiConnectionFactory" />
    <property name="sessionCacheSize" value="10" />
</bean>

connectionFactory的 - JNDI配置

<bean id="jndiName" class="java.lang.String">
    <constructor-arg value="${inventory.mq.name}"/>
</bean>

<bean id="bindingObject" class="org.springframework.jms.connection.UserCredentialsConnectionFactoryAdapter">
        <property name="targetConnectionFactory" ref="mqConnectionFactory" />
        <property name="username" value="${inventory.activeMQ.username}" />
        <property name="password" value="${inventory.activeMQ.password}" />
</bean>

<bean id="mqConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
    <property name="brokerURL" value="${inventory.activeMQ.brokerurl}" />
</bean>

属性:

inventory.activeMQ.brokerurl=tcp://localhost:61616
inventory.activeMQ.username=admin 
inventory.activeMQ.password=admin
inventory.mq.name=jms/connectionFactory
inventory.queue.type=org.apache.activemq.command.ActiveMQQueue
activemq spring-jms tomcat8
2个回答
0
投票

我有类似的问题,并发现这是Tomcat和我的web应用程序之间的类路径问题。我需要在我的web应用程序设置JMS依赖的范围提供,而不是默认(即编译)。这样一来,我的WAR部署不包含另一个JMS罐子与包含在位于在tomcat lib文件夹中的Apache的ActiveMQ的,所有jar的JMS类发生冲突。

    <dependency>
        <groupId>javax.jms</groupId>
        <artifactId>jms-api</artifactId>
        <version>1.1-rev-1</version>
        <scope>provided</scope>
    </dependency>

0
投票

尝试在调试模式跳过所有断点后/关闭调试模式或运行模式运行

© www.soinside.com 2019 - 2024. All rights reserved.