消息发送失败处理与 DLQ 补偿流程

消息发送失败处理与 DLQ 补偿流程

来自javaup中的点评plus项目,链接

当优惠券信息更改了, 使用消息发送到 Kafka 来通知消费者清除缓存,包括自己的本地缓存和 Redis 缓存,但是如果发送 Kafka 失败了呢?

流程图1

流程图2:

Mermaid 复制代码
flowchart TD
    A[业务调用 sendRecord 发送缓存失效消息] --> B[Kafka Producer 发送消息]
    
    B -->|发送成功| C[afterSendSuccess]
    C --> C1[记录成功指标]
    C1 --> C2{是否是 DLQ 重放消息?}
    C2 -->|是| C3[记录 DLQ 重放成功]
    C2 -->|否| C4[流程结束]
    
    B -->|发送失败| D[afterSendFailure]
    D --> D1[记录错误日志]
    D1 --> D2{当前 topic 是否为 DLQ?}
    D2 -->|是| D3[记录 DLQ 失败指标]
    D3 --> D4[结束]
    
    D2 -->|否| E[记录普通发送失败指标]
    E --> F[读取 headers.retryCount]
    F --> G{retryCount < 最大重试次数?}
    
    G -->|是| H[计算指数退避时间 backoff]
    H --> I[retryCount + 1]
    I --> J[写入 lastError]
    J --> K[sleepQuietly 退避等待]
    K --> L[重新 sendRecord]
    L --> B
    
    G -->|否| M[构建 DLQ 原因]
    M --> N[sendToDlq]
    N -->|成功| O[记录 DLQ 成功指标]
    O --> P[审计日志 AUDIT]
    P --> Q[结束]
    
    N -->|失败| R[记录 DLQ 失败指标]
    R --> S[人工介入]
相关推荐
武子康3 分钟前
Java-07 深入浅出 MyBatis数据库一对多关系模型实战:表结构设计与查询实现
java·后端
REDcker2 小时前
Linux OverlayFS详解
java·linux·运维
Royzst2 小时前
xml知识点
java·服务器·前端
鱼鳞_3 小时前
苍穹外卖-Day08(缓存套餐)
java·redis·缓存
过期动态3 小时前
【LeetCode 热题 100】移动零
java·数据结构·算法·leetcode·职场和发展·rabbitmq
苏渡苇4 小时前
服务容错的必要性与Spring Cloud Alibaba Sentinel 限流配置实战
spring boot·spring cloud·sentinel
bug菌4 小时前
【SpringBoot 3.x 第254节】夯爆了,数据库访问性能优化实战详解!
数据库·spring boot·后端
sinat_255487814 小时前
IDEA:查找文件/类
java·ide·设计模式·intellij-idea
不肯过江东丶4 小时前
大聪明教你学Java | Spring AI Lab:一个让你 3 分钟接入 AI 对话能力的 Spring Boot 工具箱
spring boot·后端
AI人工智能+电脑小能手5 小时前
【大白话说Java面试题 第77题】【Mysql篇】第7题:回表查询与全表扫描的区别?
java·开发语言·数据库·mysql·面试