事务消息

数据不一致

在使用消息队列时,如何保证数据一致呢?

先举一个数据不一致的例子,比如生成了一个订单,然后要通知下游服务处理相应的业务,如果此时订单创建成功,但是发送给下游的通知丢失了,就会导致数据不一致。又或者说发送给下游的通知发送成功,但是订单没有成功创建。如何解决呢?可以采用事务消息。

Tips:如果你前面看不懂,可以看后面的例子

什么是事务消息

事务消息通过 两阶段提交(2PC)事务状态回查 机制解决生产者侧的一致性问题。

1. 两阶段提交流程

  • 阶段1:发送预备消息

    • 生产者发送一条 "预备消息" 到消息队列,此消息对消费者不可见。
    • 消息队列持久化该消息并返回确认响应。
  • 阶段2:提交或回滚

    • 提交(Commit) :生产者完成本地事务(如更新数据库),通知消息队列提交预备消息,此时消息对消费者可见。
    • 回滚(Rollback) :若本地事务失败,生产者通知消息队列删除预备消息。

2. 事务状态回查

  • 超时未确认处理:若生产者未在超时时间内提交或回滚,消息队列会主动回查生产者。
  • 业务逻辑回查:生产者需实现回调接口,根据本地事务最终状态(提交或回滚)响应消息队列。

流程图

举个例子

  1. 商家接到订单之后,给配送站发一个"预备消息"
  2. 配送站收到后返回确认信息
  3. 商家开始备餐,备餐完成之后告诉配送站准备好了
  4. 配送站通知骑手

以上是顺利的情况,如果商家备餐期间发送问题,比如备到一半突然有急事(异常),通知配送站,那么配送站将其信息删除,骑手永远也不会知道这个订单;如果商家备餐期间厨房炸了(比如系统崩溃),也有可能太忙了,那么超时后配送站会打电话问商家怎么还没备好,便可知道是要通知还是删除。

相关推荐
在未来等你7 小时前
Kafka面试精讲 Day 14:集群扩容与数据迁移
大数据·分布式·面试·kafka·消息队列
在未来等你20 小时前
Kafka面试精讲 Day 8:日志清理与数据保留策略
大数据·分布式·面试·kafka·消息队列
没有bug.的程序员20 小时前
Redis Stream:轻量级消息队列深度解析
java·数据库·chrome·redis·消息队列
在未来等你2 天前
Kafka面试精讲 Day 7:消息序列化与压缩策略
大数据·分布式·面试·kafka·消息队列
在未来等你2 天前
Kafka面试精讲 Day 10:事务机制与幂等性保证
大数据·分布式·面试·kafka·消息队列
叫我阿柒啊3 天前
从Java全栈到前端框架的全面实战:一次真实面试的深度解析
java·spring boot·缓存·微服务·消息队列·vue3·rest api
喂完待续3 天前
【Big Data】Apache Kafka 分布式流处理平台的实时处理实践与洞察
分布式·kafka·消息队列·big data·数据处理·序列晋升
王嘉俊9254 天前
深入浅出 全面剖析消息队列(Kafka,RabbitMQ,RocketMQ 等)
分布式·kafka·消息队列·rabbitmq·rocketmq
叫我阿柒啊4 天前
从Java全栈到前端框架:一位程序员的实战之路
java·spring boot·微服务·消息队列·vue3·前端开发·后端开发
叫我阿柒啊4 天前
从Java全栈到云原生:一场技术深度对话
java·spring boot·docker·微服务·typescript·消息队列·vue3