8.9. Delayer
概述 复制链接链接已复制到粘贴板!
delayer 是一个处理器,可让您对传入消息应用 相对 时间延迟。
Java DSL 示例 复制链接链接已复制到粘贴板!
您可以使用 delay()
命令为传入消息添加 相对 时间延迟(以毫秒为单位)。例如,以下路由会根据 2 秒将所有传入的信息延迟:
from("seda:a").delay(2000).to("mock:result");
from("seda:a").delay(2000).to("mock:result");
另外,您可以使用表达式指定时间延迟:
from("seda:a").delay(header("MyDelay")).to("mock:result");
from("seda:a").delay(header("MyDelay")).to("mock:result");
以下 delay()
的 DSL 命令解释为 delay()
的子clauses。因此,在某些上下文中,需要通过插入 end()
命令来终止 delay()的子使用。例如,当 delay()
出现在 onException()
子句内时,您将按以下方式将它终止:
XML 配置示例 复制链接链接已复制到粘贴板!
以下示例演示了 XML DSL 中的延迟:
创建自定义延迟 复制链接链接已复制到粘贴板!
您可以使用一个表达式与 bean 合并来确定延迟,如下所示:
from("activemq:foo"). delay().expression().method("someBean", "computeDelay"). to("activemq:bar");
from("activemq:foo").
delay().expression().method("someBean", "computeDelay").
to("activemq:bar");
这里可以定义 bean 类,如下所示:
异步延迟 复制链接链接已复制到粘贴板!
您可以让延迟者使用 非阻塞异步延迟,这意味着 Apache Camel 将调度以后要执行的任务。该任务负责处理路由的后方(延迟者之后)。这允许调用器线程取消阻塞和服务进一步传入的信息。例如:
from("activemq:queue:foo") .delay(1000) .asyncDelayed() .to("activemq:aDelayedQueue");
from("activemq:queue:foo")
.delay(1000)
.asyncDelayed()
.to("activemq:aDelayedQueue");
同一路由可以使用 XML DSL 编写,如下所示:
选项 复制链接链接已复制到粘贴板!
delayer 模式支持以下选项:
名称 | 默认值 | 描述 |
|
| Camel 2.4: 如果启用,则使用调度的线程池以异步方式进行延迟。 |
|
Camel 2.4: 如果已启用 | |
|
|
Camel 2.4: 如果启用了 |