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 策略删除该消息(即视为已处理完毕,不再重试)。

以下是推荐实现:

CodeSquire
CodeSquire

AI代码编写助手,把你的想法变成代码

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

相关专题

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

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

98

2025.08.06

scripterror怎么解决
scripterror怎么解决

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

184

2023.10.18

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

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

265

2023.10.25

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

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

371

2023.07.18

堆和栈区别
堆和栈区别

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

563

2023.08.10

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

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

371

2023.07.18

堆和栈区别
堆和栈区别

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

563

2023.08.10

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

65

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

44

2025.12.31

热门下载

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

精品课程

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

共101课时 | 8.1万人学习

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

共39课时 | 3.1万人学习

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

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