jms - 在 mule 中聚合后获取 JMS 相关 ID

标签 jms mule

我有两条 JMS 出站消息,它们以分散收集方式接收,以聚合来自客户端的两条消息。然后我需要使用拆分器来拆分消息,然后通过 jms 将它们一一发送到另一个流:

<flow name="clientoneFlow1" doc:name="clientoneFlow1">
    <http:inbound-endpoint exchange-pattern="one-way" host="localhost" port="8081" path="client1" doc:name="HTTP"/>
    <component class="SalesOrder" doc:name="Java"/>
    <json:object-to-json-transformer doc:name="Object to JSON"/>
    <set-property propertyName="MULE_CORRELATION_ID" value="clientOne" doc:name="Property"/>
    <set-property propertyName="MULE_CORRELATION_SEQUENCE" value="1" doc:name="Property"/>
    <jms:outbound-endpoint queue="client1.publish" connector-ref="Active_MQ" doc:name="JMS">
        <jms:object-to-jmsmessage-transformer doc:name="Object to JMSMessage"/>
    </jms:outbound-endpoint>
</flow>

<flow name="clienttwoFlow1" doc:name="clienttwoFlow1">
        <http:inbound-endpoint exchange-pattern="one-way" host="localhost" port="8081" path="client2" doc:name="HTTP"/>
    <component class="SalesOrder2" doc:name="Java"/>
    <json:object-to-json-transformer doc:name="Object to JSON"/>
    <set-property propertyName="MULE_CORRELATION_ID" value="clientTwo" doc:name="Property"/>
    <set-property propertyName="MULE_CORRELATION_SEQUENCE" value="2" doc:name="Property"/>
    <jms:outbound-endpoint queue="client2.publish" connector-ref="Active_MQ" doc:name="JMS">
        <jms:object-to-jmsmessage-transformer doc:name="Object to JMSMessage"/>
    </jms:outbound-endpoint>
</flow>

<flow name="integration-internetsolutionsFlow1" doc:name="integration-internetsolutionsFlow1">
    <http:inbound-endpoint exchange-pattern="request-response" host="localhost" port="8081" doc:name="HTTP" path="esb"/>
    <scatter-gather doc:name="Scatter-Gather">
        <processor-chain>
            <flow-ref name="clientoneFlow1" doc:name="Flow Reference"/>
            <logger message="Client One: #[message.correlationSequence]" level="INFO" doc:name="Logger"/>
        </processor-chain>
        <processor-chain>
            <flow-ref name="clienttwoFlow1" doc:name="Flow Reference"/>
            <logger message="Client Two: #[message.correlationSequence]" level="INFO" doc:name="Logger"/>
        </processor-chain>
    </scatter-gather>
    <logger level="INFO"  message="Combined Payload: #[message.payload]" doc:name="Logger"/>
    <splitter enableCorrelation="ALWAYS" expression="#[payload]" doc:name="Splitter"/>
    <logger message="after splitter = #[payload]" level="INFO" doc:name="Logger"/>
    <logger message="Corr after splitter = #[message.correlationId] and group = #[message.correlationGroupSize]" level="INFO" doc:name="Logger"/>
    <jms:outbound-endpoint queue="validation.queue" doc:name="JMS"/>
</flow>

<flow name="validateFlow1" doc:name="validateFlow1">
    <jms:inbound-endpoint doc:name="JMS" connector-ref="Active_MQ" queue="validation.queue"/>
    <logger message="splinter payload = #[payload]" level="INFO" doc:name="Logger"/>
    <logger message="splitter corr Id = #[message.correlationId]" level="INFO" doc:name="Logger"/>
</flow>

但是在拆分器之后,两个客户端的相关 Id 已消失并分配了相同的相关 Id。如何在拆分器之后检索相关 ID?并在验证流程中根据correlationId使用消息

最佳答案

如果您使用表达式拆分器,您将使用有效负载列表进行拆分,因此每个拆分分支上都会有一个新的 MuleEvent。

如果您使用集合拆分器,则将使用 EventToMessageSequenceSplittingStrategy ,这将正确处理 MessageCollection 的分割.

因此,将分离器替换为集合分离器

关于jms - 在 mule 中聚合后获取 JMS 相关 ID,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26958223/

相关文章:

java - JBoss 5集群作为JMS服务器的持久化问题

javascript - 在 node.js 应用程序中接收 JMS 消息?

mule - DataWeave 按交替顺序组合数组

Maven 构建失败 : Failed to execute goal on project. 无法解析依赖项。无法解决 codehaus 的问题

MULE Esb xml 到对象转换器

java - Mule-使用CXF组件时出错

java - 使用什么来重播 ActiveMQ 中的消息以及为什么?

java - 消息未使用 Jboss 主题重新传送

java - Glassfish 3.1 中未找到通用资源适配器 genericra.rar

mule - Dataweave(嵌套) map 条件映射