当前位置: 首页 > wzjs >正文

dedecms网站地图插件安全的企业网站开发

dedecms网站地图插件,安全的企业网站开发,工业设计的网站,网站制作的分割线怎么做在集成RabbitMQ与Spring Boot 3.1.x时,RetryOperationsInterceptor 是实现消息重试机制的关键组件。这里将深入分析 RetryOperationsInterceptor 的工作原理,尤其是在消费者消费失败时的行为,并结合底层源码进行详解。 一、配置解析 首先&a…

在集成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();
    SimpleRetryPolicy retryPolicy = new SimpleRetryPolicy();
    retryPolicy.setMaxAttempts(3);
    retryTemplate.setRetryPolicy(retryPolicy);ExponentialBackOffPolicy backOffPolicy = new ExponentialBackOffPolicy();
    backOffPolicy.setInitialInterval(1000);
    backOffPolicy.setMultiplier(2.0);
    backOffPolicy.setMaxInterval(10000);
    retryTemplate.setBackOffPolicy(backOffPolicy);
    
  2. 执行重试:

    retryTemplate.execute(context -> {// 调用实际的消息处理方法onMessage(message);return null;
    }, context -> {// 重试失败后的回调recoverer.recover(message, context.getLastThrowable());return null;
    });
    
  3. 异常处理与恢复:

    • 每次重试失败时,RetryTemplate 会根据 BackOffPolicy 计算下次重试的等待时间。
    • 如果所有重试次数都失败,则调用 RepublishMessageRecoverer 将消息发送到死信队列。

三、与 @RabbitListener 的集成

在您的消费者代码中:

@RabbitListener(queues = RabbitConfig.MAIN_QUEUE, containerFactory = "rabbitListenerContainerFactory")
public void onMessage(String message) throws Exception {LOGGER.info("接收到消息: {}", message);// 处理消息processMessage(message);LOGGER.info("消息处理成功并确认: {}", message);
}

这里的关键在于 containerFactory 的配置,确保 RetryOperationsInterceptor 被正确应用到消息监听器容器中。

1. rabbitListenerContainerFactory 配置示例

@Bean
public SimpleRabbitListenerContainerFactory rabbitListenerContainerFactory(ConnectionFactory connectionFactory,RabbitTemplate rabbitTemplate) {SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory();factory.setConnectionFactory(connectionFactory);factory.setAcknowledgeMode(AcknowledgeMode.AUTO);factory.setAdviceChain(retryInterceptor(rabbitTemplate));return factory;
}@Bean
public RetryOperationsInterceptor retryInterceptor(RabbitTemplate rabbitTemplate) {return RetryInterceptorBuilder.stateless().maxAttempts(3).backOffOptions(1000, 2.0, 10000).recoverer(new RepublishMessageRecoverer(rabbitTemplate,DEAD_LETTER_EXCHANGE,DEAD_LETTER_ROUTING_KEY)).build();
}

在这里,RetryOperationsInterceptor 被添加到监听器容器的 adviceChain 中,使其能够拦截 onMessage 方法的执行。

四、底层源码分析

让我们更深入地看看Spring AMQP和Spring Retry的集成是如何实现的。

1. Spring AMQP 消息监听器容器

SimpleRabbitListenerContainerFactory 创建的 SimpleMessageListenerContainer 是实际的消息监听器容器。该容器负责从RabbitMQ获取消息并调用相应的监听方法。

2. RetryOperationsInterceptor 的集成

SimpleMessageListenerContainer 中,adviceChain 被应用到消息处理逻辑中。具体来说,RabbitListenerEndpointContainer#invokeListener 方法会被 RetryOperationsInterceptor 包裹,确保在调用监听方法时执行重试逻辑。

3. RetryTemplate 的执行流程

RetryOperationsInterceptor 内部使用 RetryTemplate 来管理重试流程。其核心逻辑如下:

public Object invoke(MethodInvocation invocation) throws Throwable {return retryTemplate.execute(context -> {try {return invocation.proceed();} catch (Exception e) {throw e;}}, context -> {// 重试失败后的恢复逻辑recoverer.recover(message, context.getLastThrowable());return null;});
}

在每次重试中,RetryTemplate 会调用 invocation.proceed() 执行实际的消息处理。如果抛出异常,则根据 RetryPolicy 决定是否继续重试。

4. RepublishMessageRecoverer 的作用

当所有重试尝试失败后,RepublishMessageRecoverer 会将消息重新发布到指定的死信交换机和路由键。这是通过以下方式实现的:

public void recover(Message message, Throwable cause) {MessageProperties properties = message.getMessageProperties();properties.setHeader("x-exception-stacktrace", getStackTrace(cause));rabbitTemplate.send(deadLetterExchange, deadLetterRoutingKey, message);
}

这样,未成功处理的消息不会丢失,而是被转发到死信队列,便于后续分析和处理。

五、总结

RetryOperationsInterceptor 在Spring Boot与RabbitMQ集成中,通过拦截消息处理方法的异常,按照配置的重试策略自动执行重试逻辑,极大地提高了系统的可靠性和健壮性。其底层依赖于Spring Retry的 RetryTemplateBackOffPolicy,并通过 RepublishMessageRecoverer 实现失败后的消息转发。

通过理解上述工作原理和源码实现,可以更灵活地配置和优化消息重试机制,确保消息处理的稳定性和可控性。


文章转载自:

http://8eKAsaEM.tmbtm.cn
http://aWsmVvg9.tmbtm.cn
http://Vei0qIpc.tmbtm.cn
http://asUF9DcN.tmbtm.cn
http://HxHNti2R.tmbtm.cn
http://Rpmc2k2S.tmbtm.cn
http://b9K0RXx1.tmbtm.cn
http://yciiYiKh.tmbtm.cn
http://BeauEfx3.tmbtm.cn
http://1JrKQqo3.tmbtm.cn
http://XisBJsoT.tmbtm.cn
http://DvggpfjV.tmbtm.cn
http://iJcmauRI.tmbtm.cn
http://RJYa2qx2.tmbtm.cn
http://8PEw1sVS.tmbtm.cn
http://kaIa5Qj2.tmbtm.cn
http://pKmt6Kmi.tmbtm.cn
http://BXBWERYs.tmbtm.cn
http://CtmzWn1Z.tmbtm.cn
http://snBKo8MX.tmbtm.cn
http://VJc53CnY.tmbtm.cn
http://8kjbSjJD.tmbtm.cn
http://GIeJmR6p.tmbtm.cn
http://ecvJvCMv.tmbtm.cn
http://6GYgEQ8q.tmbtm.cn
http://g07GVfrD.tmbtm.cn
http://xQGSTLIO.tmbtm.cn
http://ujHINsCb.tmbtm.cn
http://Nm1o9VgU.tmbtm.cn
http://2OdUKikF.tmbtm.cn
http://www.dtcms.com/wzjs/650968.html

相关文章:

  • 番禺电商网站建设seo学院培训班
  • 网站推广的具体方法软件下载
  • 门户网站系统开发如何推广平台
  • 常州网站建设多少钱一般的学校网站怎么做
  • 设计师网站接单网站制作简单协议
  • 网站管理员可控的关键节点微信小程序网站建设哪家好
  • 银行门户网站建设艺术品交易网站开发
  • 网站图片大小优化网站语言版本
  • 网站自然排名往后掉推荐个临汾做网站的
  • 成品网站免费下载飓风seo刷排名软件
  • 郑州旅游网站搭建wordpress post date
  • 宁波网站优化方案品牌网站建设相关问题
  • 网站建设与网页设计开题报告如何将网站提交到搜索引擎
  • 扬中网站推广托管wordpress 安装路径
  • 南坪做网站搜狗seo刷排名软件
  • 零食店网站构建策划报告免费发布信息平台有哪些
  • 安徽外贸网站建设推广普通话手抄报内容文字
  • 企业网站的步骤一个wordpress的爱好者
  • html5制作网站谁的好美工培训班一般培训多久
  • ppt免费模板下载网站有哪些政务网站建设信息
  • 文化网站建设wordpress主题代码编辑教程
  • 烟台网站设计单位网站做搜索关键字好吗
  • 网站设计制作中心做网站用什么源码最好
  • 门户网站建设服务医院风格 wordpress
  • 自动做网站的ai三峡建设管理有限公司网站
  • 网站开发完要怎么部署成都网站推广如何
  • 做网站外包多少钱建筑工程公司企业简介
  • 无锡哪个网站建设比较好免费建网站那个好
  • 免费网站安全软件下载安装个人如何加入百度推广
  • 阳江seo网站推广济南网站建设云华互动