Activemq 无法刷新目标';queue://inventorydsDestination' - 5000毫秒后重试。原因:AOP配置似乎无效
在Tomcat管理器中重新部署应用程序war时,出现以下异常。例如,在第一次部署时,它正确地连接到外部ActiveMQ,但当我在Tomcat manager中停止/启动war时,会重复抛出以下执行选项。在此之后,JMS不会连接到ActiveMQ,出现以下异常:Activemq 无法刷新目标';queue://inventorydsDestination' - 5000毫秒后重试。原因:AOP配置似乎无效,activemq,spring-jms,tomcat8,Activemq,Spring Jms,Tomcat8,在Tomcat管理器中重新部署应用程序war时,出现以下异常。例如,在第一次部署时,它正确地连接到外部ActiveMQ,但当我在Tomcat manager中停止/启动war时,会重复抛出以下执行选项。在此之后,JMS不会连接到ActiveMQ,出现以下异常: [2015-09-13T04:03:33.689] | [ERROR] | [inventorydsRequestListenerContainer-1] | [Could not refresh JMS Connection for d
[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>
我也有类似的问题,发现这是tomcat和我的web应用程序之间的类路径问题。我需要将web应用程序中jms依赖项的范围设置为提供,而不是默认值(即编译)。这样,我的WAR可部署应用程序就不包含与位于tomcat lib文件夹中的ApacheActiveMQ all jar中包含的jms类冲突的另一个jms jar
<dependency>
<groupId>javax.jms</groupId>
<artifactId>jms-api</artifactId>
<version>1.1-rev-1</version>
<scope>provided</scope>
</dependency>
javax.jms
jmsapi
1.1-rev-1
假如
在调试模式下跳过所有断点后重试/关闭调试模式或在运行模式下运行
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
<dependency>
<groupId>javax.jms</groupId>
<artifactId>jms-api</artifactId>
<version>1.1-rev-1</version>
<scope>provided</scope>
</dependency>