博客
关于我
技术干货 | 源码解析 Github 上 14.1k Star 的 RocketMQ
阅读量:163 次
发布时间:2019-02-27

本文共 863 字,大约阅读时间需要 2 分钟。

RocketMQ 事务消息发送流程分析

作为发送方,RocketMQ 的事务消息发送流程分为两个阶段:一阶段和二阶段。以下是详细的分析:

一阶段发送

一阶段发送是通过 sendMessageInTransaction 方法进行的,主要步骤包括:

  • 消息有效性校验:检查消息的有效性,包括 topic 是否有效以及消息体长度是否在允许范围内。
  • 设置事务标识符:将消息的属性中设置事务标识符,确保消息在二阶段可以正确识别。
  • 发送消息:使用同步模式发送消息到 Broker,确保发送结果。
  • 处理重试:在发送失败时,自动重试,最大重试次数为三次。
  • Broker 选择和异常规避:选择可用的 Broker,避免发送至不可用的 Broker,确保消息高效可靠地发送。
  • 本地事务执行

    一阶段发送结果确定后,决定是否执行本地事务:

  • 结果判断:根据发送结果判断是否需要执行本地事务。如果发送结果为 SEND_OK,则进入本地事务执行。
  • 本地事务执行:通过 localTransactionExecutertransactionListener 执行本地事务,确保数据一致性。
  • 状态更新:根据本地事务的执行结果,更新事务状态,决定是否提交或回滚。
  • 二阶段处理

    二阶段处理通过 endTransaction 方法进行:

  • 构造请求:构造请求头,包括事务标识符、提交或回滚的指令。
  • 发送二阶段消息:使用 oneway 模式发送二阶段消息到 Broker,确保可靠性。
  • 处理回查:Broker 在一定时间后主动回查消息状态,确保二阶段处理结果可靠。
  • 消息回查机制

    RocketMQ 的回查机制确保事务消息的二阶段结果可靠,防止消息提交不确定性。Broker 会在一定时间后回查消息状态,确保消息处理结果正确无误。

    总结

    RocketMQ 的事务消息发送流程通过一阶段同步发送和本地事务执行,确保消息可靠性;二阶段处理和回查机制,确保事务的原子性和一致性。这种设计既保证了消息的高效传输,又确保了数据的可靠性和一致性,是一个高效且可靠的消息中间件方案。

    转载地址:http://bqeb.baihongyu.com/

    你可能感兴趣的文章
    OpenCV(1)读写图像
    查看>>
    OpenCV:不规则形状区域中每种颜色的像素数?
    查看>>
    OpenCV:概念、历史、应用场景示例、核心模块、安装配置
    查看>>
    OpenDaylight融合OpenStack架构分析
    查看>>
    OpenERP ORM 对象方法列表
    查看>>
    openEuler Summit 2022 成功举行,开启全场景创新新时代
    查看>>
    openEuler 正式开放:推动计算多样化时代的到来
    查看>>
    OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_openeuler切换root用户_su:拒绝权限_passwd: 鉴定令牌操作错误---国产瀚高数据库工作笔记001
    查看>>
    OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_踩坑_安装以后系统无法联网_启动ens33网卡---国产瀚高数据库工作笔记002
    查看>>
    OpenFeign 入门与实战
    查看>>
    OpenFeign源码学习
    查看>>
    OpenFeign组件声明式服务调用
    查看>>
    openfeign远程调用不起作用解决_使用Spring Boot的spring.factories进行注入---SpringCloud Alibaba_若依微服务框架改造---工作笔记007
    查看>>
    openfire开发(四)消息拦截器
    查看>>
    openfire源码解读之将cache和session对象移入redis以提升性能
    查看>>
    Openfire身份认证绕过漏洞复现+利用(CVE-2023-32315)
    查看>>
    OpenForest 开源项目安装与使用指南
    查看>>
    OpenGL glBlendFunc() 设置颜色混合 透明度叠加计算
    查看>>
    opengl 教程(15) 摄像机控制(2)
    查看>>
    opengl 深度详解,多重采样时,如何在OpenGL纹理中解析深度值?
    查看>>