27、分布式事务:原理、实现与示例

分布式事务:原理、实现与示例

在分布式系统中,事务管理是一个至关重要的问题。本文将深入探讨分布式事务的相关概念,包括请求处理流程、ACID 与 BASE 事务的对比、本地事务和分布式事务的区别,以及通过一个具体的示例展示如何使用 MySQL、ActiveMQ、Derby 和 Atomikos 实现分布式事务。

1. 请求处理流程

当 REST 控制器接收到请求后,会按照 CQRS 模式对请求进行处理。具体流程如下:
1. 请求解析与命令创建 :REST 控制器解包请求后,将其解释为实体变更请求,并创建一个命令。
2. 命令发送与事务启动 :该命令被发送到分布式命令总线,启动本地事务。
3. 命令传输 :分布式命令总线将命令传输到包含相应命令处理程序的节点(资源管理器 3)。
4. 实体写入 :命令处理程序借助写入数据库(Write DB)中的存储库对实体进行写入操作。
5. 事件触发与发送 :存储库的变更会触发一个事件,并将该事件发送到集群事件总线。
6. 事件处理 :不同的事件处理程序(资源管理器 1 和资源管理器 2)会对该事件感兴趣,并可能进行相应的状态变更。
7. 数据同步与查询可见性 :资源管理器 2 会同步系统中的有趣变更,后续的查询(HTTP GET)也能看到这些变更。

以下是该流程的 mermaid 流程图:

<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值