2.18. Core
Camel 核心功能和基本 Camel 语言/常量、交换属性、Header、Ref、Simple 和 Tokenize
2.18.1. 内部是什么 复制链接链接已复制到粘贴板!
有关使用和配置详情,请参阅上述链接。
2.18.2. Maven 协调 复制链接链接已复制到粘贴板!
在 code.quarkus.redhat.com 上使用此扩展创建一个新项目
或者将协调添加到现有项目中:
<dependency>
<groupId>org.apache.camel.quarkus</groupId>
<artifactId>camel-quarkus-core</artifactId>
</dependency>
<dependency>
<groupId>org.apache.camel.quarkus</groupId>
<artifactId>camel-quarkus-core</artifactId>
</dependency>
2.18.3. 其他 Camel Quarkus 配置 复制链接链接已复制到粘贴板!
2.18.3.1. 简单语言 复制链接链接已复制到粘贴板!
2.18.3.1.1. 使用 OGNL 表示法 复制链接链接已复制到粘贴板!
使用简单语言中的 OGNL 表示法时,应使用 camel-quarkus-bean 扩展。
例如,以下简单的表达式是访问类型为 Client 的消息正文的 getAddress () 方法。
---
simple("${body.address}")
---
---
simple("${body.address}")
---
在这种情况下,应该依赖 camel-quarkus-bean 扩展的额外依赖项 ,如下所述。请注意,在原生模式中,可能需要注册一些类来反映。在上例中,Client 类需要 进行注册以进行反映。
2.18.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'")
---
---
simple("${body} is 'java.nio.ByteBuffer'")
---
因此,类 java.nio.ByteBuffer 需要注册来反映。
2.18.3.1.3. 在原生模式中使用带有 classpath 资源的简单语言 复制链接链接已复制到粘贴板!
如果您的路由应该从 classpath 加载一个简单脚本,如下例所示
from("direct:start").transform().simple("resource:classpath:mysimple.txt");
from("direct:start").transform().simple("resource:classpath:mysimple.txt");
然后,您需要使用 Quarkus quarkus.native.resources.includes 属性将资源包含在原生可执行文件中,如下所示:
quarkus.native.resources.includes = mysimple.txt
quarkus.native.resources.includes = mysimple.txt
2.18.3.1.4. 通过原生模式的属性配置自定义 bean 复制链接链接已复制到粘贴板!
当通过原生模式中的属性指定自定义 bean 时,如 #class:* or #type:*,可能需要注册一些类来手动反映。
例如,以下自定义 bean 定义涉及对 bean 实例化和 setter 调用进行反映:
--- camel.beans.customBeanWithSetterInjection = #class:org.example.PropertiesCustomBeanWithSetterInjection camel.beans.customBeanWithSetterInjection.counter = 123 ---
---
camel.beans.customBeanWithSetterInjection = #class:org.example.PropertiesCustomBeanWithSetterInjection
camel.beans.customBeanWithSetterInjection.counter = 123
---
因此,类 PropertiesCustomBeanWithSetterInjection 需要为反映注册,请注意,在这种情况下可以省略字段访问权限。
| 配置属性 | 类型 | 默认 |
|---|---|---|
|
当设置为 true 时, |
|
|
|
以逗号分隔的 Ant-path 风格模式列表,以匹配 classpath 中的 Camel 服务定义文件。匹配文件中定义的服务无法通过 |
| |
|
以逗号分隔的 Ant-path 风格模式列表,以匹配 classpath 中的 Camel 服务定义文件。匹配文件中定义的服务将通过 |
| |
|
以逗号分隔的 Ant-path 风格模式列表,以匹配 classpath 中的 Camel 服务定义文件。在应用的静态初始化过程中,匹配文件中定义的服务不会添加到 Camel registry 中。excludes 的优先级高于 includes。此处定义的 excludes 还可以用来传递 Camel Quarkus 扩展中包含的服务的注册。示例值: |
| |
|
以逗号分隔的 Ant-path 风格模式列表,以匹配 classpath 中的 Camel 服务定义文件。匹配文件中定义的服务将在应用程序的静态初始化过程中添加到 Camel registry 中,除非给定的文件通过 |
| |
|
如果为 |
|
|
|
如果为 |
|
|
|
如果为 |
|
|
|
如果为 |
|
|
|
在静态初始化过程中启用自动发现路由。 |
|
|
|
用于独占过滤 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/* |
| |
|
由 Camel Quarkus 2.0.0 中的 |
| |
|
由 Camel Quarkus 2.0.0 中的 |
| |
|
以逗号分隔的 Ant-path 风格模式列表,以匹配应排除在 Register for reflection 中的类名称。使用 |
| |
|
以逗号分隔的 Ant-path 风格模式列表,以匹配应该注册以进行反映的类名称。使用 |
| |
|
如果为 |
|
|
|
如果构建时无法从路由定义中提取 CSimple 表达式,则做什么。 |
|
|
|
是否启用 Camel 事件到 CDI 事件。这允许为 Camel 事件配置 CDI 观察器。例如,那些属于 |
|
|
|
启用/禁用 camel 源位置的构建时间配置选项 |
|
|
|
等待 |
|
|
|
|
|
|
构建时修复的配置属性。所有其他配置属性可在运行时覆盖。