RocketMQ事务消息实战

本文围绕RocketMQ事务消息实现原理,通过订单流转场景探讨了三种解决方案,包括官方示例和事务监听器的实现。同时提供了Java开发者面试题的相关资源。
摘要由CSDN通过智能技术生成

RocketMQ事务消息阅读目录指引:

RocketMQ源码分析之从官方示例窥探RocketMQ事务消息实现基本思想

RocketMQ源码分析之RocketMQ事务消息实现原理上篇

RocketMQ源码分析之RocketMQ事务消息实现原理中篇----事务消息状态回查

RocketMQ源码分析之事务消息实现原理下篇-消息服务器Broker提交回滚事务实现原理

RocketMQ事务消息实战


我们以一个订单流转流程来举例,例如订单子系统创建订单,需要将订单数据下发到其他子系统(与第三方系统对接)这个场景,我们通常会将两个系统进行解耦,不直接使用服务调用的方式进行交互。其业务实现步骤通常为:

1、A系统创建订单并入库。

2、发送消息到MQ。

3、MQ消费者消费消息,发送远程RPC服务调用,完成订单数据的同步。

1、方案一

这里写图片描述

方案弊端:

1、如果消息发送成功,在提交事务的时候JVM突然挂掉,事务没有成功提交,导致两个系统之间数据不一致。

2、由于消息是在事务提交之前提交,发送的消息内容是订单实体的内容,会造成在消费端进行消费时如果需要去验证订单是否存在时可能出现订单不存在。

3、消息发送可以考虑异步发送。

方案二:

由于存在上述问题,在MQ不支持事务消息的前提条件下,可以采用下面的方式进行优化。

这里写图片描述

然后在控制器层,使用异步发送,将消息发送,并在消息发送成功后,更新待发送状态为已发送。

然后通过定时任务,扫描待发送,结合创建时间的记录(小于当前时间5分钟的消息待发送记录),进行消息发送。

方案弊端:

1、消息有可能重复发送,但在消费端可以通过唯一业务编号来进行去重设计。

2、实现过于复杂,为了避免 极端情况下的消息丢失,需要使用定时任务。

方案三:基于RocketMQ4.3版本事务消息

这里写图片描述

额外需要实现事务会查监听器:TransactionListener,其实例代码:

import org.apache.rocketmq.client.producer.LocalTransactionState;

import org.apache.rocketmq.client.producer.TransactionListener;

import org.apache.rocketmq.common.message.Message;

import org.apache.rocketmq.common.message.MessageExt;

import java.util.concurrent.ConcurrentHashMap;

@SuppressWarnings(“unused”)

public class OrderTransactionListenerImpl implements TransactionListener {

private ConcurrentHashMap<String, Integer> countHashMap = new ConcurrentHashMap<>();

private final static int MAX_COUNT = 5;

@Override

public LocalTransactionState executeLocalTransaction(Message msg, Object arg) {

//

String bizUniNo = msg.getUserProperty(“bizUniNo”); // 从消息中获取业务唯一ID。

// 将bizUniNo入库,表名:t_message_transaction,表结构 bizUniNo(主键),业务类型。

return LocalTransactionState.UNKNOW;
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后

面试题文档来啦,内容很多,485页!

由于笔记的内容太多,没办法全部展示出来,下面只截取部分内容展示。

1111道Java工程师必问面试题

MyBatis 27题 + ZooKeeper 25题 + Dubbo 30题:

Elasticsearch 24 题 +Memcached + Redis 40题:

Spring 26 题+ 微服务 27题+ Linux 45题:

Java面试题合集:

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!
试题合集:**

[外链图片转存中…(img-oicAEdvR-1712188030893)]

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!

  • 10
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值