异常有效负载从一个流传递到另一个流,该流由Vm端点连接

时间:2014-05-20 09:17:40

标签: exception-handling mule mule-studio

您好我有一个mflow文件,其中包含保存Vm入站端点的flow1。通过此vm端点,我连接同一项目中另一个mflow文件中存在的另一个flow2。在flow2中抛出异常我需要在flow1中捕获它。我可以看到flow1中的异常有效负载来自flow2.But flow1没有将它识别为异常并传递给flow的其他组件而不是发送它来捕获block.help我在解决这个问题。我需要抓住它在主流中,即仅流量1。   并行流将与此流一起运行,并且我正在聚合两个响应。如果其中一个流抛出异常,则它不应该影响另一个并行流的执行。

1 个答案:

答案 0 :(得分:1)

调用流不会捕获异常,因为异常不会跨端点传播。

您可以将流2更改为子流或私有流(未定义异常策略)并删除vm-endpoint。这样,流程1将捕获并处理异常。

    <flow name="flow1">
        <flow-ref name="flow2" />       

        <catch-exception-strategy>
            <logger level="ERROR" message="Caught exception in flow1" />
        </catch-exception-strategy>
    </flow>

    <sub-flow name="flow2">
    ...
    </sub-flow>

或者您可以使用过滤器或选择路由器来过滤异常。

    <flow name="flow1">
        ...
        <vm:outbound-endpoint exchange-pattern="request-response" address="vm://flow2" />

        <choice>
            <when expression="#[exception != null]">
                <logger level="ERROR" message="exception in flow2" />
            </when>
            <otherwise>
                <logger />
            </otherwise>
        </choice>
    </flow>

    <flow name="flow2">
        <vm:inbound-endpoint exchange-pattern="request-response" address="vm://flow2" />
        <null-component></null-component>
    </flow>