5.5. 消息路由器


概述

消息路由器 (如 图 5.7 “消息路由器模式” 所示)是一个过滤器,它消耗来自单个消费者端点的信息,并根据特定决策条件将它们重定向到适当的目标端点。消息路由器仅关注重定向消息;它不会修改消息内容。

但是,默认情况下,当 Camel 将消息交换路由到接收方端点时,它发送是原始交换对象的粗略副本。在粗略复制中,原始交换的元素(如消息正文、标头和附加)仅通过参考来复制。通过发送可重复利用资源的粗略副本,Camel 优化性能。但是,由于这些 shouldow 副本都是链接,因此当 Camel 将消息路由到多个端点时,代价是丢失了将自定义逻辑应用到路由到不同接收方的能力。有关如何启用 Camel 将消息的唯一版本路由到不同的端点的详情,请参考 "将自定义处理应用到传出消息"。

图 5.7. 消息路由器模式

消息路由器模式

可以使用 choice () 处理器在 Apache Camel 中轻松实施消息路由器,其中每个替代目标端点都可以使用 when () 子模块(有关选择处理器的详情,请参阅 第 1.5 节 “处理器”)。

Java DSL 示例

以下 Java DSL 示例演示了如何根据 foo 标头的内容将消息路由到三个替代目的地( seda:aseda:bseda:c):

from("seda:a").choice()
    .when(header("foo").isEqualTo("bar")).to("seda:b")
    .when(header("foo").isEqualTo("cheese")).to("seda:c")
    .otherwise().to("seda:d");

XML 配置示例

以下示例演示了如何在 XML 中配置相同的路由:

<camelContext id="buildSimpleRouteWithChoice" xmlns="http://camel.apache.org/schema/spring">
  <route>
    <from uri="seda:a"/>
    <choice>
      <when>
        <xpath>$foo = 'bar'</xpath>
        <to uri="seda:b"/>
      </when>
      <when>
        <xpath>$foo = 'cheese'</xpath>
        <to uri="seda:c"/>
      </when>
      <otherwise>
        <to uri="seda:d"/>
      </otherwise>
    </choice>
  </route>
</camelContext>

没有其他选择

如果您使用没有 otherwise () 子句的 choice (),则默认丢弃任何不匹配的交换。

Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

© 2024 Red Hat, Inc.