登录 |  注册
首页 >  面试合集 >  Java大厂面经-复习笔记-更新中 >  什么是half message(半消息)

什么是half message(半消息)

Half message 是在消息队列(Message Queue,MQ)领域,尤其是阿里巴巴开源的消息中间件 RocketMQ 中提到的一个术语,它特指一种特殊的事务消息状态。在分布式事务处理的上下文中,半消息(Half Message)指的是那些已被生产者成功发送到消息队列服务器,但由于生产者尚未完成本地事务并发送二次确认,所以暂时不能被消费者消费的消息。

RocketMQ.png

在RocketMQ的事务消息模型中,半消息的生命周期包括以下几个步骤:

  1. 生产者首先发送一条半事务消息到MQ服务端。

  2. MQ服务端接收到消息后立即返回确认(ACK),但并不立即投递给消费者,而是将其标记为“暂不能投递”状态,即半消息状态。

  3. 生产者在接收到MQ服务端的确认之后开始执行本地事务。

  4. 根据本地事务的执行结果,生产者向MQ服务端发送commit(提交)请求,表示事务已成功执行,MQ可以将该消息投递给消费者;或者发送rollback(回滚)请求,表示事务执行失败,MQ应删除该消息。

  5. 如果MQ在指定的超时时间内未收到生产者的二次确认(commit或rollback),MQ将会主动发起一次回查,询问生产者事务的状态。

这种事务消息机制确保了在分布式系统中,消息的生产和消费能够与业务逻辑的执行保持一致,从而实现了分布式事务的最终一致性。

上一篇: 可靠消息的服务方案是什么
推荐文章
  • Halfmessage是在消息队列(MessageQueue,MQ)领域,尤其是阿里巴巴开源的消息中间件RocketMQ中提到的一个术语,它特指一种特殊的事务消息状态。在分布式事务处理的上下文中,半消息(HalfMessage)指的是那些已被生产者成功发送到消息队列服务器,但由于生产者尚未完成本地事
  • 可靠消息服务方案是一种用于确保在分布式系统中实现消息传递最终一致性的技术方案。在分布式事务处理中,尤其是在微服务架构或者分布式系统架构下,不同服务之间需要通过异步消息通信来协调事务,而直接使用传统的ACID事务往往难以满足高并发、高性能的需求。可靠消息服务(ReliableMessageServic
  • TCC(Try-Confirm-Cancel)是一种分布式事务解决方案,该方案由分布式事务协调专家LeslieLamport提出,并在实践中逐渐演化和发展。TCC模式常用于微服务架构下的分布式事务场景,它的核心思想是在每个参与分布式事务的服务中实现三个阶段的操作:Try阶段:这个阶段是尝试阶段,服务
  • 对于Java资深工程师的面试,面试官通常会期望候选人能深入理解Java的核心概念、设计模式、框架原理、并发编程、JVM优化、以及实际项目中的最佳实践等方面的知识。以下是一些可能会被问到的资深Java面试题示例:Java基础部分Java内存模型(JMM)是如何工作的?解释Java中的内存泄漏,并给出具
  • 1、Goroutine定义 Golang在语言级别支持协程,称之为Goroutine。Golang标准库提供的所有系统调用操作(包括所有的同步I/O操作),都会出让CPU给其他Goroutine。这让Goroutine的切换管理不依赖于系统的线程和进程,也不依赖于CPU的核心数量,而是交给Golan
  • Go基础面试题1、与其他语言相比,使用Go有什么好处?与其他作为学术实验开始的语言不同,Go代码的设计是务实的。每个功能和语法决策都旨在让程序员的生活更轻松。Golang针对并发进行了优化,并且在规模上运行良好。由于单一的标准代码格式,Golang通常被认为比其他语言更具可读性。自动垃圾收集明显比J
学习大纲