RocketMQ事务消息实战,Java最新实习面试经验总结

本文介绍了RocketMQ事务消息的实战应用,包括在Java后端开发中遇到的问题及解决方案。讨论了方案二和方案三,即异步发送与基于RocketMQ 4.3的事务消息处理,同时提到了面试中可能涉及的一线大厂Java面试题。
摘要由CSDN通过智能技术生成

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

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

方案二:

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

这里写图片描述

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

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

方案弊端:

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

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

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

这里写图片描述

额外需

《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》

【docs.qq.com/doc/DSmxTbFJ1cmN1R2dB】 完整内容开源分享

要实现事务会查监听器:TransactionListener&

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值