我有一个使用 Kafka 活页夹的 Spring Cloud Stream 项目,我正在尝试理解并最终自定义 Cloud Stream 使用的 RetryTemplate。
我没有找到很多关于它是如何工作的文档,但我读过的内容让我做出了以下假设:
- Cloud Stream 默认配置并启用 Spring Retry,包括默认的重试和退避策略。
- 默认情况下,任何未捕获的异常
@StreamListener
都会触发 Spring Retry - Cloud Stream 将以某种方式跟踪每条消息的 RetryContext 信息(如何?我不确定)
这些假设是否正确?
现在,在我的应用程序中,我有一个模式可以立即处理一些消息,但必须推迟其他消息稍后再试(使用指数退避等)。
我应该抛出异常导致 Spring Cloud Stream 在绑定层重试这些消息,还是自己实现重试并跟踪我自己的重试上下文?
如果我应该依赖 Cloud Stream 的重试设置,我应该如何自定义退避策略等?