• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

springboot整合rocketmq实现分布式事务

springboot 搞代码 4年前 (2022-01-05) 13次浏览 已收录 0个评论
文章目录[隐藏]

大多数情况下很多公司是使用消息队列的方式实现分布式事务。 本篇文章重点讲解springboot环境下整合rocketmq实现分布式事务,感兴趣的可以了解一下

1 执行流程

(1) 发送方向 MQ 服务端发送消息。
(2) MQ Server 将消息持久化成功之后,向发送方 ACK 确认消息已经发送成功,此时消息为半消息。
(3) 发送方开始执行本地事务逻辑。
(4) 发送方根据本地事务执行结果向 MQ Server 提交二次确认(Commit 或是 Rollback),MQ Server 收到Commit 状态则将半消息标记为可投递,订阅方最终将收到该消息;MQ Server 收到 Rollback 状态则删除半消息,订阅方将不会接受该消息。
(5) 在断网或者是应用重启的特殊情况下,上述步骤4提交的二次确认最终未到达 MQ Server,经过固定时间后MQ Server 将对该消息发起消息回查。
(6) 发送方收到消息回查后,需要检查对应消息的本地事务执行的最终结果。
(7) 发送方根据检查得到的本地事务的最终状态再次提交二次确认,MQ Server 仍按照步骤4对半消息进行操作。

2 工程

2.1 pom

  org.springframework.bootspring-boot-starter-parent2.3.0.RELEASE<!-- lookup parent from repository --> 1.8  org.springframework.bootspring-boot-starter-web org.springframework.bootspring-boot-starter-testtest org.projectlomboklombok com.alibabafastjson1.2.71 org.apache.commonscommons-collections44.2 org.apache.commonscommons-lang3 org.springframework.bootspring-boot-starter-logging<!-- https://mvnrepository.com/artifact/org.apache.rocketmq/rocketmq-spring-boot-starter --> org.apache.rocketmqrocketmq-spring-boot-starter2.0.1 org.apache.rocketmqrocketmq-client4.3.2   org.springframework.bootspring-boot-maven-plugin2.3.0.RELEASE org.apache.maven.pluginsmaven-compiler-plugin3.8.1 1.81.8

来源gao!%daima.com搞$代*!码网

2.2 application.yml

 rocketmq: name-server: 192.168.38.50:9876 producer: group: transcation-group 

2.3 TransactionListenerImpl

 @RocketMQTransactionListener(txProducerGroup = "transaction-producer-group") @Slf4j public class TransactionListenerImpl implements RocketMQLocalTransactionListener { private static Map STATE_MAP = new HashMap(); /** *  执行业务逻辑 */ @Override public RocketMQLocalTransactionState executeLocalTransaction(Message message, Object o) { String transId = (String) message.getHeaders().get(RocketMQHeaders.TRANSACTION_ID); try { System.out.println("用户A账户减500元."); System.out.println("用户B账户加500元."); STATE_MAP.put(transId, RocketMQLocalTransactionState.COMMIT); return RocketMQLocalTransactionState.COMMIT; } catch (Exception e) { e.printStackTrace(); } STATE_MAP.put(transId, RocketMQLocalTransactionState.ROLLBACK); return RocketMQLocalTransactionState.UNKNOWN; } /** * 回查 */ @Override public RocketMQLocalTransactionState checkLocalTransaction(Message message) { String transId = (String) message.getHeaders().get(RocketMQHeaders.TRANSACTION_ID); log.info("回查消息 -> transId ={} , state = {}", transId, STATE_MAP.get(transId)); return STATE_MAP.get(transId); } } 

2.4 SpringTransactionProducer

 @Component @Slf4j public class SpringTransactionProducer { @Autowired private RocketMQTemplate rocketMQTemplate; /** * 发送消息 * */ public void sendMsg(String topic, String msg) { Message message = MessageBuilder.withPayload(msg).build(); this.rocketMQTemplate.sendMessageInTransaction("transaction-producer-group", topic, message, null); log.info("发送成功"); } } 

2.5 SpringTxConsumer

 @Component @RocketMQMessageListener(topic = "pay_topic", consumerGroup = "transaction-consumer-group", selectorExpression = "*") @Slf4j public class SpringTxConsumer implements RocketMQListener { @Override public void onMessage(String msg) { log.info("接收到消息 -> {}", msg); } } 

2.6 ProducerController

 @RestController @RequestMapping("/producer") public class ProducerController { @Autowired private SpringTransactionProducer springTransactionProducer; @GetMapping("/sendMsg") public String sendMsg() { springTransactionProducer.sendMsg("pay_topic", "用户A账户减500元,用户B账户加500元。"); return "发送成功"; } } 

2.7 RocketApplication

 @SpringBootApplication public class RocketApplication { public static void main(String[] args) { SpringApplication.run(RocketApplication.class); } } 

3 测试

3.1 正常消费测试

描述: 正常启动及可。

3.2 回查代码测试

描述: 执行本地事务时添加异常,重启测试,发现消费者没有收到消息。

到此这篇关于springboot整合rocketmq实现分布式事务的文章就介绍到这了,更多相关springboot 分布式事务内容请搜索gaodaima搞代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持gaodaima搞代码网

以上就是springboot整合rocketmq实现分布式事务的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:springboot整合rocketmq实现分布式事务
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址