Mule 2.2.6 - 处理JMS连接丢失的策略

时间:2013-03-05 09:00:23

标签: jms activemq mule

我正在使用Mule 2.2.6,具有以下设置:

2台服务器,每台服务器都有一个ActiveMQ实例 1台运行Mule 2.2.6的服务器

现在,我有一个服务从一个ActiveMQ中获取消息,并将其放在另一个上。但是,当目标ActiveMQ关闭时,这会导致丢失消息的问题。然后,Mule将从源ActiveMQ中获取一条消息,但在尝试将其放在目标AtiveMQ上时会遇到此异常:

ERROR [org.mule.DefaultExceptionStrategy] Caught exception in Exception Strategy: No JMS Connection 
java.lang.IllegalStateException: No JMS Connection
    at org.mule.transport.jms.JmsMessageDispatcher.doDispatch(JmsMessageDispatcher.java:81)
    at org.mule.transport.AbstractMessageDispatcher.dispatch(AbstractMessageDispatcher.java:105)
    at org.mule.transport.AbstractConnector$DispatchWorker.doRun(AbstractConnector.java:2561)
    at org.mule.work.AbstractMuleEventWork.run(AbstractMuleEventWork.java:41)
    at org.mule.work.WorkerContext.run(WorkerContext.java:310)
    at edu.emory.mathcs.backport.java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1061)
    at edu.emory.mathcs.backport.java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:575)
    at java.lang.Thread.run(Thread.java:662)

一旦发生这种情况,信息就会丢失,远低于可接受的信息。

在检查mule配置时,我注意到没有与将服务从一个ActiveMQ移动到另一个ActiveMQ的服务关联的jms-transactions,但是在添加事务之后,问题仍然是相同的。

配置:

ActiveMQ连接器:

<jms:activemq-connector name="jmsConnectorOuter" specification="1.1"
    persistentDelivery="true" disableTemporaryReplyToDestinations="true" honorQosHeaders="true"
    numberOfConsumers="1" connectionFactory-ref="activeMqConnectionFactoryOuter" maxRedelivery="-1">
    <ee:retry-forever-policy frequency="5000" asynchronous="false" />
</jms:activemq-connector>

<jms:activemq-connector name="jmsConnector" specification="1.1"
    persistentDelivery="true" disableTemporaryReplyToDestinations="true" honorQosHeaders="true"
    numberOfConsumers="1" connectionFactory-ref="activeMqConnectionFactory" maxRedelivery="-1">
    <ee:retry-forever-policy frequency="5000" asynchronous="false" />
</jms:activemq-connector>

JMS-端点:

<endpoint name="queue.destination" address="jms://queue.destination" connector-ref="jmsConnector" />

<endpoint name="queue.source" address="jms://queue.source" connector-ref="jmsConnectorOuter" />

服务:

<service name="OuterActiveMQService">
    <inbound>
        <jms:inbound-endpoint ref="queue.source">
           <jms:transaction action="ALWAYS_BEGIN" timeout="60000" />
        </jms:inbound-endpoint>
    </inbound>

    <outbound>
        <pass-through-router>
            <jms:outbound-endpoint ref="queue.destination" />
        </pass-through-router>
    </outbound>
</service>

当与目的地的ActiveMQ连接丢失时,可以做些什么来确保消息不会丢失?

1 个答案:

答案 0 :(得分:2)

您需要添加:

<jms:transaction action="ALWAYS_JOIN" />

在出站JMS端点中,使其加入事务。