无法刷新目标'queue:// inventorydsDestination'的JMS连接 - 在5000毫秒内重试。原因:AOP配置似乎无效

时间:2015-09-13 10:56:40

标签: activemq spring-jms tomcat8

当我在Tomcat管理器中重新部署应用程序战争时,我遇到以下异常。例如,在第一次部署时,它正确地连接到外部ActiveMQ,但是当我在Tomcat管理器中停止/启动战争时,将重复抛出以下execption。在此之后,JMS没有连接到ActiveMQ,但有以下异常:

<div class="fullwidth">
  <div class="left"></div>
  <div class="center"></div>
  <div class="right"></div>
</div>

的applicationContext-jms.xml文件

[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]

connectionFactory - JNDI配置

<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>

属性:

<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>

2 个答案:

答案 0 :(得分:0)

我有类似的问题,发现它是tomcat和我的Web应用程序之间的类路径问题。我需要在我的Web应用程序中设置jms依赖项的范围而不是默认值(即编译)。这样,我的WAR deployable不包含另一个jms jar,它与位于tomcat lib文件夹中的apache-activemq-all jar中包含的jms类发生冲突。

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

答案 1 :(得分:0)

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

运行