2.26. Core
Camel 核心功能和基本 Camel 语言:Constant、ExchangeProperty、Header、Ref、Simple 和 Tokenize
2.26.1. 什么是内部 复制链接链接已复制到粘贴板!
有关用法和配置详情,请参阅上述链接。
2.26.2. Maven 协调 复制链接链接已复制到粘贴板!
在 code.quarkus.redhat.com 上使用此扩展创建新项目
或者将协调添加到现有项目中:
<dependency>
<groupId>org.apache.camel.quarkus</groupId>
<artifactId>camel-quarkus-core</artifactId>
</dependency>
2.26.3. 其他 Camel Quarkus 配置 复制链接链接已复制到粘贴板!
2.26.3.1. 简单语言 复制链接链接已复制到粘贴板!
2.26.3.1.1. 使用 OGNL 表示法 复制链接链接已复制到粘贴板!
从简单语言使用 OGNL 表示法时,应使用 camel-quarkus-bean 扩展。
例如,以下简单的表达式正在访问类型为 Client 的消息正文上的 getAddress () 方法。
---
simple("${body.address}")
---
在这种情况下,一个应该对 camel-quarkus-bean 扩展进行额外的依赖关系 ,如下所述。请注意,在原生模式中,可能需要注册一些类来反映。在上例中,Client 类需要 进行注册以进行反映。
2.26.3.1.2. 在原生模式中使用动态类型解析 复制链接链接已复制到粘贴板!
当从简单表达式动态解析类型时,如:
-
simple("${mandatoryBodyAs(TYPE)}") -
simple("${type:package.Enum.CONSTANT}") -
from("…").split(bodyAs(TYPE.class)) -
simple ("${body} is TYPE")
可能需要注册一些类来手动反映。
例如,以下简单表达式在运行时动态解析 java.nio.ByteBuffer 类型:
---
simple("${body} is 'java.nio.ByteBuffer'")
---
因此,类 java.nio.ByteBuffer 需要注册来反映。
2.26.3.1.3. 在原生模式中使用带有 classpath 资源的简单语言 复制链接链接已复制到粘贴板!
如果您的路由应该从 classpath 加载一个简单脚本,如下例所示
from("direct:start").transform().simple("resource:classpath:mysimple.txt");
然后,您需要使用 Quarkus quarkus.native.resources.includes 属性在原生可执行文件中包含资源,如下所示:
quarkus.native.resources.includes = mysimple.txt
有关选择包含在原生可执行文件中的资源的更多信息,请参阅 原生可执行文件 中的 组合资源。
2.26.3.1.4. 通过原生模式中的属性配置自定义 bean 复制链接链接已复制到粘贴板!
当通过原生模式中的属性指定自定义 bean 时,如 #class:* or #type:*,可能需要注册一些类来手动反映。
例如,以下自定义 bean 定义涉及对 bean 实例化和 setter 调用使用 reflection:
---
camel.beans.customBeanWithSetterInjection = #class:org.example.PropertiesCustomBeanWithSetterInjection
camel.beans.customBeanWithSetterInjection.counter = 123
---
因此,类 PropertiesCustomBeanWithSetterInjection 需要为反映注册,请注意,在这种情况下可以省略字段访问权限。
| 配置属性 | 类型 | default |
|---|---|---|
|
当设置为 true 时, |
|
|
|
以逗号分隔的 Ant 路径风格模式列表,以匹配 classpath 中的 Camel 服务定义文件。匹配文件中定义的服务 无法通过 ** excludes 的优先级高于 includes。此处定义的 excludes 也可以用来发现由 Camel Quarkus 扩展包括的服务。
示例值: |
| |
|
以逗号分隔的 Ant 路径风格模式列表,以匹配 classpath 中的 Camel 服务定义文件。匹配文件中定义的服务可通过
请注意,默认情况下,Camel Quarkus 扩展可能包含一些服务。此处选择的服务添加到这些服务中,在
示例值: |
| |
|
以逗号分隔的 Ant 路径风格模式列表,以匹配 classpath 中的 Camel 服务定义文件。在应用程序的静态初始化过程中,匹配文件中定义的服务不会添加到 Camel registry 中。 excludes 的优先级高于 includes。此处定义的 excludes 也可以用来注册 Camel Quarkus 扩展中包含的服务。
示例值: |
| |
|
以逗号分隔的 Ant 路径风格模式列表,以匹配 classpath 中的 Camel 服务定义文件。匹配文件中定义的服务将在应用程序的静态初始化过程中添加到 Camel registry 中,除非通过
请注意,默认情况下,Camel Quarkus 扩展可能包含一些服务。此处选择的服务添加到这些服务中,在
示例值: |
| |
|
如果为
把它设置为 |
|
|
|
如果为
把它设置为 |
|
|
|
如果为
把它设置为 |
|
|
|
如果为
把它设置为 |
|
|
|
如果为
把它设置为 |
|
|
|
如果为
把它设置为 |
|
|
|
启用在静态初始化过程中自动发现路由。 |
|
|
|
用于对 RouteBuilder 类进行独占过滤扫描。独占过滤优先于包含的过滤。模式使用 Ant-path 风格模式。可以使用逗号分隔多个模式。例如,要排除所有以 Bar 开始的类,使用:**/Bar*;要排除所有组成一个特定数据包的路由,使用:com/mycompany/bar/*;要排除所有组成一个特定数据包和它的子数据包的路由,使用双通配符:com/mycompany/bar/**;要排除所有来自两个特定数据包的路由,使用:com/mycompany/bar/*,com/mycompany/stuff/* |
| |
|
用于对 RouteBuilder 类进行包含过滤扫描。独占过滤优先于包含的过滤。模式使用 Ant-path 风格模式。可以使用逗号分隔多个模式。例如,要包括所有以 Foo 开始的类,使用:**/Foo*;要包括所有组成一个特定数据包的路由,使用:com/mycompany/foo/*;要包括所有组成一个特定数据包和它的子数据包的路由,使用双通配符:com/mycompany/foo/**;要包括所有来自两个特定数据包的路由,使用:com/mycompany/foo/*,com/mycompany/stuff/* |
| |
|
以逗号分隔的 Ant-path 风格模式列表,以匹配应在注册进行反映 中排除的 类名称。使用
这个选项缩小由 这个选项无法用于取消注册由 Quarkus 扩展内部注册的类。 |
| |
|
以逗号分隔的 Ant 路径风格模式列表,以匹配应注册的类名称。使用
默认情况下,不包含任何类。此选项选择的集合可以通过 请注意,Quarkus 扩展通常自行注册所需的类来反映。当内置功能不足时,此选项很有用。
请注意,这个选项启用对构造器、字段和方法的完整反映访问。如果您需要精细的控制,请考虑使用 Java 代码中的 要使这个选项正常工作,必须至少满足以下条件之一:
- 在模式中没有通配符(
其中 |
| |
|
如果为 |
|
|
|
如果构建时无法从路由定义中提取 CSimple 表达式,则应该做什么。 |
|
|
|
如果构建时无法从路由定义中提取表达式,该怎么办。 |
|
|
|
指明是否需要在构建时从路由定义中提取表达式。如果禁用,则在运行时编译表达式。 |
|
|
|
是否启用 Camel 事件桥接到 CDI 事件。
这允许为 Camel 事件配置 CDI 观察程序。例如,属于 请注意,当应用程序中存在为 Camel 事件配置的观察程序时,此配置项目才会生效。 |
|
|
|
启用/禁用 camel 源位置的构建时间配置选项。 |
|
|
|
在 Camel 应用程序中启用 tracer。 |
|
|
|
要将 tracer 设置为待机模式,将安装 tracer,但不会自动启用 tracer。然后,tracer 可以从 Java、JMX 或工具显式启用。 |
|
|
|
定义 tracer 中要保留的最后一个消息数量。 |
|
|
|
在 tracer 转储时,是否应该删除所有 traced 消息。默认情况下,消息会被删除,这意味着转储不包含之前转储的消息。 |
|
|
|
将消息正文限制为 traced 消息中的最大大小。使用 0 或负值使用无限大小。 |
|
|
|
是否包含基于流的消息的消息正文。如果启用然后是启用的,则流稍后可能无法被重新读取。请参阅有关流缓存的更多信息。 |
|
|
|
是否包含基于文件的消息的消息正文。开销是必须从文件中读取文件内容。 |
|
|
|
是否在 traced 消息中包含交换属性。 |
|
|
|
是否在 traced 消息中包含交换变量。 |
|
|
|
在交换失败时,是否在 trace 的消息中包含异常。 |
|
|
|
是否追踪从 Rest DSL 创建的路由。 |
|
|
|
是否追踪从路由模板或 kamelets 创建的路由。 |
|
|
|
根据路由或节点 id 过滤以进行追踪。 |
| |
|
过滤用于追踪消息。 |
| |
|
是否启用类型转换器统计信息。默认情况下,类型转换器使用率统计被禁用。请注意,启用统计会对非常重度负载造成较小的性能影响。 |
|
|
|
一个超时(具有 millisecond 精度)等待 |
|
|
|
在 |
|
|
在构建时修复的配置属性。所有其他配置属性可在运行时覆盖。
要写入持续时间值,请使用标准 java.time.Duration 格式。如需更多信息,请参阅 Duration#parse ()Java API 文档。
您还可以使用简化的格式,从数字开始:
- 如果值只是一个数字,它代表时间(以秒为单位)。
-
如果值为数字,后跟
ms,代表时间(毫秒)。
在其他情况下,简化的格式被转换为 java.time.Duration 格式以进行解析:
-
如果该值是一个数字,后跟
h、m或s,则前缀为PT。 -
如果值为数字,后跟
d,则会以P为前缀。