0

0

AWS SQS 消息失败重试策略:仅对自定义异常触发重试

霞舞

霞舞

发布时间:2026-01-02 12:06:42

|

773人浏览过

|

来源于php中文网

原创

AWS SQS 消息失败重试策略:仅对自定义异常触发重试

在 spring cloud aws 中,通过 `@sqslistener` 配合 `on_success` 删除策略时,需手动捕获非目标异常,仅让特定自定义异常(如 `mycustomexception`)向上抛出以触发消息重试,其余异常应静默吞并或记录,避免意外丢消息。

当使用 SqsMessageDeletionPolicy.ON_SUCCESS 时,SQS 消息仅在方法正常返回(无异常)时自动删除;一旦方法抛出任何未捕获的异常,Spring 将默认执行失败处理逻辑(如将消息放回队列或进入死信队列,取决于 SQS 的 RedrivePolicy 和 VisibilityTimeout 设置)。但问题核心在于:我们不希望所有异常都触发重试——例如 NullPointerException 或 IllegalArgumentException 往往代表代码缺陷或数据脏污,应被拦截并记录,而非盲目重试,否则可能造成重复处理、状态不一致甚至死循环。

✅ 正确做法是:用 try-catch 显式包裹业务逻辑,仅重新抛出白名单内的自定义异常(如 MyCustomException),其他异常则统一捕获、记录日志,并不抛出,从而让方法“静默成功”退出,使 SQS 按 ON_SUCCESS 策略删除该消息(即视为已处理完毕,不再重试)。

以下是推荐实现:

Play.ht
Play.ht

根据文本生成多种逼真的语音

下载
@SqsListener(
    value = "https://sqs.us-east-1.amazonaws.com/123456789012/MyQueueURL",
    deletionPolicy = SqsMessageDeletionPolicy.ON_SUCCESS
)
public void getMessageFromSqs(MyMessage message) {
    try {
        log.info("Processing message: {}", message);

        if (someCondition()) {
            throw new MyCustomException("Business rule violated — retry required");
        }

        // ✅ 业务逻辑成功完成
        log.info("Message processed successfully");

    } catch (MyCustomException e) {
        log.warn("Custom exception encountered, allowing retry", e);
        throw e; // ? 关键:仅此异常透出,触发 SQS 重试
    } catch (Exception e) {
        // ⚠️ 兜底捕获:所有其他异常(NPE、JSON parse error、DB timeout 等)
        log.error("Unexpected error — suppressing to avoid unintended retry", e);
        // 不抛出 → 方法正常结束 → ON_SUCCESS 生效 → 消息被删除
    }
}

? 关键注意事项:

  • 勿滥用静默吞并:catch (Exception e) 吞并所有异常虽可防止误重试,但也掩盖了潜在 Bug。务必确保 log.error 包含完整堆,并接入告警系统(如 CloudWatch Alarms + Slack)。
  • 自定义异常需继承 RuntimeException:Spring 的异常传播机制默认只对 RuntimeException 及其子类触发重试行为(检查 SqsMessagingTemplate 默认错误处理器逻辑)。
  • 配合 SQS 队列配置:确保队列设置了合理的 VisibilityTimeout(大于方法最大执行耗时)和 maxReceiveCount(配合 DLQ 使用),避免因超时导致重复投递。
  • 幂等性仍是基石:即使精准控制重试,消费者端仍必须实现幂等设计(如基于 messageId 或业务唯一键去重),因为网络抖动、实例重启等场景仍可能导致重复消息。

总结:ON_SUCCESS 是一种“乐观删除”策略,它把失败判定权完全交还给开发者。通过精细的异常分类与受控抛出,你能在保障系统健壮性的同时,实现语义清晰、可运维的消息重试边界。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

154

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

88

2026.01.26

Java 微服务与 Spring Cloud 实战
Java 微服务与 Spring Cloud 实战

本专题讲解 Java 微服务架构的开发与实践,重点使用 Spring Cloud 实现服务注册与发现、负载均衡、熔断与限流、分布式配置管理、API Gateway 和消息队列。通过实际项目案例,帮助开发者理解 如何将传统单体应用拆分为高可用、可扩展的微服务架构,并有效管理和调度分布式系统中的各个组件。

50

2026.02.05

Java 微服务与 Spring Cloud 实战
Java 微服务与 Spring Cloud 实战

本专题讲解 Java 微服务架构的开发与实践,重点使用 Spring Cloud 实现服务注册与发现、负载均衡、熔断与限流、分布式配置管理、API Gateway 和消息队列。通过实际项目案例,帮助开发者理解 如何将传统单体应用拆分为高可用、可扩展的微服务架构,并有效管理和调度分布式系统中的各个组件。

50

2026.02.05

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

472

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

373

2023.10.25

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

435

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

601

2023.08.10

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

46

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 10万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号