忍受我,因为我被困在最简单的Mule ESB / JMS用例上。我正在尝试使用Mule应用程序接受来自现有HornetQ队列的传入消息。我的mule-config.xml如下所示。我的问题是这个;每当消息生成器向队列添加消息时,HornetQ就会报告消息达到给定消息的最大重传次数并将其发送到死信队列 - 显然Mule JMS inbound从未接受过 - 端点。这仅在Mule服务器运行时发生(重要的是要注意应用程序部署在Mule服务器中而没有问题),当它不是时,当然提供商不会尝试任何预期的交付。我已经在其他应用程序中使用hornet配置来设置消息监听器到同一个HornetQ实例而没有问题。非常感谢任何帮助。
<?xml version="1.0" encoding="UTF-8"?>
<mule xmlns="http://www.mulesoft.org/schema/mule/core"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:beans="http://www.springframework.org/schema/beans"
xmlns:jms="http://www.mulesoft.org/schema/mule/jms"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
http://www.mulesoft.org/schema/mule/core http://www.mulesoft.org/schema/mule/core/3.4/mule.xsd
http://www.mulesoft.org/schema/mule/jms http://www.mulesoft.org/schema/mule/jms/3.4/mule-jms.xsd">
<beans:bean id="hornetConnectionFactory" class="org.hornetq.jms.client.HornetQXAConnectionFactory">
<beans:constructor-arg name="ha" value="false" />
<beans:constructor-arg>
<beans:bean class="org.hornetq.api.core.TransportConfiguration">
<beans:constructor-arg value="org.hornetq.core.remoting.impl.netty.NettyConnectorFactory" />
<beans:constructor-arg>
<beans:map key-type="java.lang.String" value-type="java.lang.Object">
<beans:entry key="host" value="localhost"/>
<beans:entry key="port" value="5445"/>
</beans:map>
</beans:constructor-arg>
</beans:bean>
</beans:constructor-arg>
</beans:bean>
<beans:bean id="cachingConnectionFactory" class="org.springframework.jms.connection.CachingConnectionFactory">
<beans:constructor-arg ref="hornetConnectionFactory" />
</beans:bean>
<beans:bean id="transactionalConnectionFactory" class="org.springframework.jms.connection.TransactionAwareConnectionFactoryProxy">
<beans:property name="targetConnectionFactory" ref="cachingConnectionFactory" />
<beans:property name="synchedLocalTransactionAllowed" value="true" />
</beans:bean>
<jms:connector name="jmsConnector" specification="1.1" connectionFactory-ref="transactionalConnectionFactory"
validateConnections="true" acknowledgementMode="AUTO_ACKNOWLEDGE" disableTemporaryReplyToDestinations="true" />
<flow name="MyFlow">
<jms:inbound-endpoint connector-ref="jmsConnector" queue="MyQueue"
exchange-pattern="one-way" />
<logger message="Message #[payload.id] processed successfully" level="DEBUG"/>
</flow>
</mule>
答案 0 :(得分:0)
我想知道问题是否是由于您使用事务连接工厂的事实:不确定Mule是否可以利用它,或者可能它可以,但您必须使您的JMS入站端点事务处理。
您是否尝试过使用hornetConnectionFactory
中的裸jms:connector
?