5.3. 消息端点


概述

消息端点 是应用程序和消息传递系统之间的接口。如 图 5.3 “消息端点模式” 所示,您可以有一个发送者端点,有时被称为代理或服务消费者,它负责发送 In 消息和接收器端点,有时也称为端点或服务,它负责 接收信息

图 5.3. 消息端点模式

消息端点模式

端点类型

Apache Camel 定义两种基本端点类型:

  • Apache Camel 路由开始时的消费者 端点 HEKETI Appears,并从传入频道读取 In 消息(等同于 接收器 端点)。
  • 在 Apache Camel 路由结束时生成者 端点 HEKETI Appears,并将 In 消息写入传出频道(等同于 发送者 端点)。可以使用多个制作者端点定义路由。

端点 URI

在 Apache Camel 中,端点由 端点 URI 表示,它通常封装以下类型的数据:

  • 消费者端点 wagon-wagon Advertises 的端点 URI (例如,要公开发送者可以连接到的服务)。或者,URI 可以指定消息源,如消息队列。端点 URI 可以包含用于配置端点的设置。
  • 生成者端点 wagon-wagon 包含发送消息的位置的端点 URI,并包含用于配置端点的设置。在某些情况下,URI 指定远程接收器端点的位置;在其他情况下,目标可以有一个抽象形式,如队列名称。

Apache Camel 中的端点 URI 具有以下通用形式:

ComponentPrefix:ComponentSpecificURI

其中 ComponentPrefix 是用于标识特定 Apache Camel 组件的 URI 前缀(请参阅 Apache Camel 组件参考 以了解所有受支持组件的详细信息)。URI 组件SpecificURI 的其余部分具有特定组件定义的语法。例如,要连接到 JMS 队列 Foo.Bar,您可以定义如下所示的端点 URI:

jms:Foo.Bar

要定义将消费者端点 file://local/router/messages/foo 连接到制作者端点 jms:Foo.Bar 的路由,您可以使用以下 Java DSL 片段:

from("file://local/router/messages/foo").to("jms:Foo.Bar");

另外,您可以在 XML 中定义相同的路由,如下所示:

<camelContext id="CamelContextID" xmlns="http://camel.apache.org/schema/spring">
  <route>
    <from uri="file://local/router/messages/foo"/>
    <to uri="jms:Foo.Bar"/>
  </route>
</camelContext>

动态到

& lt;toD > 参数允许您使用连接在一起的一个或多个表达式向动态计算端点发送消息。

默认情况下,使用 Simple 语言计算端点。以下示例将消息发送到标头定义的端点:

<route>
  <from uri="direct:start"/>
  <toD uri="${header.foo}"/>
</route>

在 Java DSL 中,同一命令的格式是:

from("direct:start")
  .toD("${header.foo}");

URI 也可以以文字作为前缀,如下例所示:

<route>
  <from uri="direct:start"/>
  <toD uri="mock:${header.foo}"/>
</route>

在 Java DSL 中,同一命令的格式是:

from("direct:start")
  .toD("mock:${header.foo}");

在上例中,如果 header.foo 的值为 orange,则 URI 将解析为 mock:orange

要使用 Simple 以外的语言,您需要定义 language: 参数。请参阅 第 II 部分 “路由表达式和 predicates 语言”

使用不同语言的格式是使用 URI 中的 语言:languagename :。例如,要使用 Xpath,请使用以下格式:

<route>
  <from uri="direct:start"/>
  <toD uri="language:xpath:/order/@uri/">
</route>

以下是 Java DSL 中的相同示例:

from("direct:start")
  .toD("language:xpath:/order/@uri");

如果没有指定 language:,则端点是一个组件名称。在某些情况下,一个组件和语言具有相同的名称,如 xquery。

您可以使用 + 符号连接多个语言。在以下示例中,URI 是 Simple 和 Xpath 语言的组合。simple 是默认值,因此无需定义语言。+ 符号是 Xpath 指令后,使用 language:xpath 表示。

<route>
  <from uri="direct:start"/>
  <toD uri="jms:${header.base}+language:xpath:/order/@id"/>
</route>

在 Java DSL 中,格式如下:

from("direct:start")
  .toD("jms:${header.base}+language:xpath:/order/@id");

许多语言可以一次串联,每个语言都与 + 分开,并使用 语言名称指定各个语言

以下选项可通过 toD 提供:

Name

默认值

描述

uri

 

必需:要使用的 URI。

pattern

 

设置一个特定的 Exchange Pattern,以便在发送到端点时使用。之后会恢复原始 MEP。

cacheSize

 

配置 ProducerCache 的缓存大小,它将缓存生成者以供重复使用。默认缓存大小为 1000,如果没有指定其他值,则会使用它。将值设为 -1 可完全关闭缓存。

ignoreInvalidEndpoint

false

指定是否忽略无法解析的端点 URI。如果禁用,Camel 将抛出一个识别无效端点 URI 的异常。

Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

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

让开源更具包容性

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

關於紅帽

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

© 2024 Red Hat, Inc.