拦截器堆栈的Mule ESB问题

时间:2013-09-05 19:02:36

标签: mule interceptor

我是Mule的新手,在使用拦截器堆栈元素方面遇到了麻烦。

以下内容似乎是在他们的文档中采用的:http://www.mulesoft.org/documentation/display/33X/Using+Interceptors

<interceptor-stack name="default">
    <logging-interceptor/>
    <timer-interceptor/>
</interceptor-stack>

<flow name="MyFlowFlow1" doc:name="MyFlowFlow1">

    <interceptor-stack ref="default"/>  <!--this is line 15 -->
    <logger level="INFO" message="Got here"/>

</flow>    

但我得到一个例外,说它无效。

有人能告诉我我做错了吗?

org.xml.sax.SAXParseException; lineNumber: 15; columnNumber: 43; cvc-complex-type.2.4.a: Invalid content was found starting with element 'interceptor-stack'. One of '{"http://www.mulesoft.org/schema/mule/core":annotations, "http://www.mulesoft.org/schema/mule/core":description, "http://www.mulesoft.org/schema/mule/core":abstract-message-source, "http://www.mulesoft.org/schema/mule/core":abstract-inbound-endpoint, "http://www.mulesoft.org/schema/mule/core":abstract-message-processor, "http://www.mulesoft.org/schema/mule/core":abstract-outbound-endpoint, "http://www.mulesoft.org/schema/mule/core":abstract-mixed-content-message-processor, "http://www.mulesoft.org/schema/mule/core":response}' is expected.
at org.apache.xerces.util.ErrorHandlerWrapper.createSAXParseException(Unknown Source)
...etc...

编辑 - 这是为了解决以下问题。

当通过flow-ref从另一个流调用时,第一个私有流完美地工作。我看到“到了这里”的消息和时间。

<flow name="test2Flow1" doc:name="test2Flow1">
    <timer-interceptor/>
    <logger level="INFO" message="got here" doc:name="Logger"/>
</flow>

但是,当从另一个流调用时,第二个私有流不起作用...事实上,它甚至不会解析。唯一的区别是timer-interceptor的显式使用被更改为对包含timer-interceptor的拦截器堆栈的引用。

<interceptor-stack name="default">
    <timer-interceptor/>
</interceptor-stack>

<flow name="test2Flow1" doc:name="test2Flow1">
    <interceptor-stack ref="default"/>
    <logger level="INFO" message="got here" doc:name="Logger"/>
</flow>

3 个答案:

答案 0 :(得分:0)

我认为您的流量无效,因为它没有消息处理器。

看一下流动的解剖学。

http://www.mulesoft.org/documentation/display/current/Using+Flows+for+Service+Orchestration#UsingFlowsforServiceOrchestration-TheAnatomyofaFlow

答案 1 :(得分:0)

您的消息处理器必须是流程中的第一项

答案 2 :(得分:0)

拦截器应在组件内使用 此配置应该有效:

<interceptor-stack name="default">
    <logging-interceptor/>
    <timer-interceptor/>
</interceptor-stack>

<flow name="test2Flow1" doc:name="test2Flow1">
    <pooled-component class="com.MyComponent">
        <interceptor-stack ref="default"/>  <!--this is line 15 -->
    </pooled-component>
    <logger level="INFO" message="Got here"/>
</flow>