如何在Camel中延迟重试

时间:2016-01-19 06:28:05

标签: java routes apache-camel

我有兴趣在Camel中使用RedeliveryPolicy在返回某个异常时重试将消息重新传递到端点。但我似乎找不到很多如何配置它的例子。

目前我正在尝试:

    from("direct:entry")
            .onException(ResourceNotFoundException.class)
                .redeliveryPolicy(new RedeliveryPolicy().delayPattern("delayPattern=0:" + aocmDelay + ",10:1000;15:2000:19:10000"))
                .handled(true)
            .end()
            .to("direct:destination");

我的目标端点失败并出现ResourceNotFoundException但是没有调用onException处理并且重新传递没有生效。对我做错了什么想法?

1 个答案:

答案 0 :(得分:2)

您需要设置重新投放政策的单个属性。

from("direct:entry")
    .onException(ResourceNotFoundException.class)
        .maximumRedeliveries(20)
        .delayPattern("1:2000;10:1000;15:2000;19:10000")
        .handled(true)
        .end()
    .to("direct:destination");

补充意见:

  • 您需要定义最大重新传递尝试(如果未在别处定义),否则使用默认值为零
  • 在延迟模式中你有两个错别字
    delayPattern=0:" + aocmDelay + ",10:1000;15:2000:19:10000
    ________________________________;_______________;________
  • 重新传递计数以1开头,如果您定义0:1000;1:5000,则第一次重新发送会延迟五秒而非一个