news 2026/4/23 13:49:20

RocketMQ的事务消息是如何实现的?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
RocketMQ的事务消息是如何实现的?

RocketMQ 通过 TransactionListener 接口实现事务消息机制,其工作流程如下:

  1. 发送半消息
    首先向 Broker 发送一条半消息(状态标记为"prepared"),该消息会被存储在事务日志中但暂不可消费。

  2. 执行本地事务
    半消息发送成功后,应用程序执行本地事务逻辑并确定最终状态。

  3. 提交/回滚

    • 本地事务成功:通知 Broker 提交消息(状态改为"committed"),消息转为可消费状态
    • 本地事务失败:通知 Broker 回滚消息(状态改为"rollback"),消息会被立即删除

异常处理机制

未收到确认指令时
若 Broker 未及时收到 COMMIT/ROLLBACK:

  1. 主动发起事务状态检查
  2. 应用程序通过回调返回处理结果
  3. 若超时未响应则标记为"UNKNOW"状态
  4. 最终过期后自动回滚

半消息发送失败
由于业务操作在半消息之后执行:

  • 失败时业务尚未执行,不存在一致性问题
  • 可通过重试机制解决(自主重试或依赖上游重试)

设计优势

相比"先提交事务再发消息"的传统方案,事务消息解决了:

  1. 最终一致性
    即使 COMMIT 消息发送失败,MQ 仍能通过半消息状态反查确保最终一致
  2. 防丢失
    本地事务提交与消息投递形成原子操作,避免"事务成功但消息丢失"的情况
  3. 状态可追踪
    通过 prepared/committed/rollback 状态机明确消息生命周期
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 7:00:03

AEAD 加密技术详解及 TLS1.3 应用

一、AEAD 基础原理 1.1 定义与核心特 AEAD (Authenticated Encryption with Associated Data) 是一种同时提供机密性、完整性和认证性的加密技术,能够在单一算法中处理数据加密和验证,解决了传统加密与认证分离方案的安全隐患。其核心特性包括如下几点:…

作者头像 李华
网站建设 2026/4/23 11:14:49

Kotaemon能否实现问答结果的自动归档?

Kotaemon能否实现问答结果的自动归档? 在企业智能化转型加速的今天,一个常见的痛点逐渐浮现:用户与AI助手的每一次对话,是否只能停留在“问完即止”的层面?特别是在金融、医疗、法务等强合规性领域,监管要求…

作者头像 李华
网站建设 2026/4/23 12:13:48

软件外包与人才服务型上市公司设计资金管理平台,需结合行业特性(项目制、人力成本为主、多客户结算、周期性收款等)和上市公司合规要求

软件外包与人才服务型上市公司设计资金管理平台,需结合行业特性(项目制、人力成本为主、多客户结算、周期性收款等)和上市公司合规要求。以下是一个系统化的设计框架:一、核心目标资金可视化管理:实时监控现金流、账户…

作者头像 李华
网站建设 2026/4/23 11:56:17

资金管理平台概率性现金流预测模型(机器学习)

特征工程class CashFlowFeatureEngineer:"""现金流特征工程"""def create_features(self, historical_data: pd.DataFrame, future_dates: pd.DatetimeIndex) -> pd.DataFrame:"""创建机器学习特征historical_data: 历史现金流…

作者头像 李华