Spring-rabbit重试消费源码分析

在集成RabbitMQ与Spring Boot 3.1.x时,RetryOperationsInterceptor 是实现消息重试机制的关键组件。这里将深入分析 RetryOperationsInterceptor 的工作原理,尤其是在消费者消费失败时的行为,并结合底层源码进行详解。

一、配置解析

首先,需要提供 RetryOperationsInterceptor 配置如下:

// 配置重试拦截器
RetryOperationsInterceptor retryInterceptor = RetryInterceptorBuilder.stateless()
        .maxAttempts(3) // 初次消费 + 2次重试
        .backOffOptions(1000, 2.0, 10000) // 初始间隔1秒,倍增因子2.0,最大间隔10秒
        .recoverer(new RepublishMessageRecoverer(
                rabbitTemplate,
                DEAD_LETTER_EXCHANGE,
                DEAD_LETTER_ROUTING_KEY))
        .build();

这段配置的含义如下:

  • maxAttempts(3): 设置最大尝试次数为3次,包括初次消费和2次重试。
  • backOffOptions(1000, 2.0, 10000): 设置重试的间隔策略,初始间隔为1秒,倍增因子为2.0,最大间隔为10秒。
  • recoverer: 当所有重试尝试失败后,使用 RepublishMessageRecoverer 将消息转发到指定的死信交换机和路由键。

二、RetryOperationsInterceptor 的工作原理

RetryOperationsInterceptor 是Spring Retry提供的拦截器,用于在方法执行失败时自动进行重试。结合Spring AMQP(RabbitMQ)的消息监听器容器,它能够在消息处理失败时执行重试逻辑。

1. 消息消费流程

当RabbitMQ消费者接收到消息时,以下步骤会依次执行:

  1. 消息接收: 消息被送到监听方法 onMessage
  2. 消息处理: 执行 processMessage(message) 方法进行业务处理。
  3. 成功确认: 如果处理成功,消息被确认(ACK)。
  4. 处理失败: 如果抛出异常,触发重试机制。

2. 重试拦截器的作用

processMessage 方法抛出异常时,RetryOperationsInterceptor 会拦截这个异常,并按照配置的重试策略进行重试。具体流程如下:

  1. 拦截异常: 异常被 RetryOperationsInterceptor 捕获。
  2. 执行重试: 根据 backOffOptions 设置的间隔和倍增因子,等待指定时间后重新执行 onMessage 方法。
  3. 重试次数限制: 如果重试次数未超过 maxAttempts,则继续重试;否则,执行 recoverer 逻辑。

3. 重试逻辑的底层实现

从源码角度看,RetryOperationsInterceptor 主要依赖于 RetryTemplate 来执行重试逻辑。以下是关键步骤:

  1. 构建 RetryTemplate:

    RetryTemplate retryTemplate = new RetryTemplate(
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值