分布式事务解决方案简介
一、分布式事务的挑战
在分布式系统中,多个服务协同完成一个业务操作时,可能会遇到数据一致性问题。传统单体应用的ACID事务无法直接扩展到分布式环境,主要矛盾在于:
• 网络不可靠:服务间通信可能失败。
• 并发冲突:多节点同时修改同一数据。
• 容错性要求高:需在部分服务宕机时仍保证最终一致性。
二、主流分布式事务解决方案
1. XA协议(Two-Phase Commit)
• 核心思想:通过两阶段提交(准备阶段+提交阶段)确保所有参与者统一提交或回滚。
• 流程:
- Phase 1 (Prepare):协调者询问各事务节点是否可提交。
- Phase 2 (Commit/Rollback):若所有节点均同意,则提交;否则触发回滚。
• 优点:强一致性,符合ACID。
• 缺点:
• 单点故障(协调者宕机)。
• 长时间阻塞资源(尤其是第二阶段延迟)。
• 适用场景:金融等对一致性要求极高且容忍低延迟的场景。
• Java实现:通过javax.transaction.xa包,如JTA(Java Transaction API)。
// XA资源管理器示例
XAResource xaResource = ...;
int txId = xaResource.start(tx, XAResource.TMNOFLAGS);
// 执行本地事务
xaResource.prepare(tx);
// 提交/回滚
xaResource.commit(tx, false); // 或rollback
2. TCC模式(Try-Confirm-Cancel)
• 核心思想:将事务拆分为三个阶段,通过补偿操作实现最终一致性。
• 流程:
- Try:业务服务尝试执行,记录操作日志。
- Confirm:若所有Try成功,提交事务。
- Cancel:任一服务失败,触发逆向补偿。
• 优点:
• 避免锁表,提升并发性能。
• 适合长事务或复杂业务逻辑。
• 缺点:
• 代码量大(需手动实现补偿逻辑)。
• 补偿失败需重试机制。
• 适用场景:电商订单、支付扣款等业务流程。
• Java实现:可通过Spring Cloud Alibaba Seata集成TCC。
// TCC服务示例
@Compensable(confirmMethod="confirmOrder", cancelMethod="cancelOrder")
public void createOrder(Order order) {// 1. 尝试下单(扣库存、生成订单)inventoryService.deduct(order.getSkuId());orderDAO.insert(order);
}public void confirmOrder(Order order) {// 确认订单完成(如发送通知)
}public void cancelOrder(Order order) {// 补偿操作:恢复库存、删除订单inventoryService.restore(order.getSkuId());orderDAO.delete(order.getId());
}
3. Saga模式
• 核心思想:将大事务分解为多个本地事务,通过事件驱动补偿机制。
• 流程:
- 主事务发起事件,触发下游服务。
- 每个服务完成后发布事件,若失败则触发补偿事件。
• 优点:
• 异步解耦,高吞吐。
• 适合微服务架构。
• 缺点:
• 依赖事件监听机制的可靠性。
• 补偿顺序需严格设计。
• 适用场景:用户注册、优惠券发放等松耦合场景。
• Java实现:Apache Camel、Spring Event、Kafka消息队列。
// Saga事件示例
@Component
public class OrderSaga {@EventListenerpublic void handleOrderCreated(OrderCreatedEvent event) {// 扣减库存inventoryService.deduct(event.getSkuId());// 发布库存扣减成功事件applicationEventPublisher.publishEvent(new InventoryDeductedEvent(...));}@EventListenerpublic void handleInventoryDeducted(InventoryDeductedEvent event) {// 发送订单确认邮件emailService.sendConfirmationEmail(event.getOrder());}
}
4. Seata(分布式事务解决方案)
• 核心思想:基于AT(Automatic Transaction)模式,结合动态代理实现无侵入式事务管理。
• 流程:
- Branch Registration:注册分支事务。
- Transaction Context Propagation:通过RPC透传上下文。
- Undo Log:自动记录逆向操作日志,用于回滚。
• 优点:
• 对业务代码零侵入。
• 支持AT、TCC、XA多种模式。
• 适用场景:快速接入分布式事务的Spring Boot应用。
• Java实现:Spring Cloud Alibaba Seata。
// Seata AT模式示例(无需显式编码)
@Service
public class UserService {@Transactionalpublic void createUser(User user) {userDAO.insert(user); // 自动记录undo logemailService.sendWelcomeEmail(user.getEmail()); // 参与者}
}
5. 本地消息表(最终一致性)
• 核心思想:通过异步消息表记录操作,定期同步状态。
• 流程:
- 业务服务写入本地事务+消息表。
- 消息消费者异步处理下游服务。
- 监控消息处理状态,失败则重试。
• 优点:
• 高性能,低延迟。
• 实现简单。
• 缺点:
• 需处理消息重复消费问题。
• 最终一致性而非实时一致。
• 适用场景:日志记录、统计类操作。
• Java实现:RocketMQ、Kafka + Spring Batch。
// 消息表示例
@Data
@Entity
public class OrderMessage {@Id@GeneratedValue(strategy = GenerationType.IDENTITY)private Long id;private String orderId;private String status; // ORDER_CREATED, PROCESSEDprivate LocalDateTime createTime;
}
三、方案对比与选型建议
| 方案 | 一致性级别 | 性能 | 开发成本 | 适用场景 |
|---|---|---|---|---|
| XA | 强一致 | 低 | 高 | 金融核心系统 |
| TCC | 最终一致 | 中 | 中 | 订单支付 |
| Saga | 最终一致 | 高 | 高 | 微服务解耦场景 |
| Seata(AT) | 强一致 | 高 | 低 | 快速接入的Spring Boot项目 |
| 本地消息表 | 最终一致 | 极高 | 低 | 异步日志、统计 |
四、总结
• 强一致性优先:选XA或Seata。
• 高性能与复杂业务:选TCC或Saga。
• 异步解耦:选本地消息表。
• 快速落地:直接采用Seata框架。
实际项目中,常结合多种模式(如Seata + Saga)应对不同场景,需根据业务需求、团队技术栈及系统规模综合决策。
相关文章:
分布式事务解决方案简介
一、分布式事务的挑战 在分布式系统中,多个服务协同完成一个业务操作时,可能会遇到数据一致性问题。传统单体应用的ACID事务无法直接扩展到分布式环境,主要矛盾在于: • 网络不可靠:服务间通信可能失败。 • 并发冲突…...
【leetcode hot 100 17】电话号码的字母组合
分析:当设计关键字“所有组合”时,要考虑深度优先遍历、广度优先遍历(层次遍历),其中: 深度优先搜索: 自顶向下的递归实现深搜定义子问题在当前递归层结合子问题结果解决原问题 广度优先搜索 利…...
UI数据处理新隐私保护:确保用户新信息安全
hello宝子们...我们是艾斯视觉擅长ui设计和前端数字孪生、大数据、三维建模、三维动画10年经验!希望我的分享能帮助到您!如需帮助可以评论关注私信我们一起探讨!致敬感谢感恩! 在这个数字时代,我们的个人信息似乎无处不在。从社交媒体上的点滴分享,到在线…...
【Javascrip】Javascript练习01 REST API using Express.js.
针对该问题的项目路径 要求部分 what you need to doReview the tasks provided in the section below.Obtain the boilerplate code.Use your local development environment to implement a solution.Upload your solution for marking via Gradescope. There is no attempt…...
分析K8S中Node状态为`NotReady`问题
在Kubernetes(k8s)集群中,Node状态为NotReady通常意味着节点上存在某些问题,下面为你分析正常情况下节点应运行的容器以及解决NotReady状态的方法。 正常情况下Node节点应运行的容器 1. kubelet kubelet是节点上的核心组件&…...
小样本学习综述
小样本学习综述 📕[1]潘雪玲,李国和,郑艺峰. 面向深度网络的小样本学习综述 [J]. 计算机应用研究, 2023, 40 (10): 2881-28882895. DOI:10.19734/j.issn.1001-3695.2023.02.0074. 主要是该论文的一些摘要。 小样本学习旨在利用较少目标数据训练模型快速学习的。 …...
挂谷问题与挂谷猜想:从平面转针到高维拓扑
挂谷问题与挂谷猜想:从平面转针到高维拓扑 目录 挂谷问题的起源数学定义与基本性质研究进展挂谷集合与挂谷猜想王虹与Joshua Zahl的突破意义与影响 挂谷问题的起源 1917年,日本数学家挂谷宗一(かけや そういち Soichi Kakeya,1886-1947)提…...
火语言RPA--表格数据导出
表格数据导出 🚩【组件功能】:导出表格内数据到指定的文件 配置预览 配置说明 导出格式 Excel:导出Excel文档格式,CSV:导出CSV数据格式。 导出文件夹 支持T或# 导出文件需要保存的文件夹路径。 导出文件名支持T或# 导出文…...
数学建模:MATLAB卷积神经网络
一、简述 卷积神经网络是一种处理具有网格结构数据的深度学习模型,由输入层、卷积层、池化层、全连接层、输出层组成。 输出层:将图像转换为其对应的由像素值构成的二维矩阵,并存储二维矩阵 卷积层:提取图像的底层特征…...
Vue3 基础语法指南:响应式系统与 Ref 应用
1、Reactive 的深度响应式 1.1、基本用法 vue <script setup> import { reactive } from vueconst state reactive({count: 0,user: {name: Alice,age: 30} })const increment () > state.count const updateName () > state.user.name Bob </script>1…...
学习笔记:黑马程序员JavaWeb开发教程(2025.3.21)
10.10 案例-员工管理-删除员工 前端中有两个删除按键,一个是删除员工,一个是批量删除,我们只需要将删除员工作为特殊的批量删除,就是只删除一个,开发一个接口就行 用id in ()来批量删除&…...
xLua_003 Lua访问C#
1、new C# 对象(创建游戏物体) LuaCallCSharp.cs using UnityEngine; using XLua;public class LuaCallCSharp : MonoBehaviour {public LuaEnv env null;void Start(){LuaEnv env new LuaEnv();env.DoString("requireLuaCallCSharp");}pr…...
mysql 磐维(opengauss)tidb误删数据之高级恢复
Mysql参考: Mysql 8.0 XtraBackupMysqlbinlog 完全恢复 - 墨天轮 Mysql 8.0 XtraBackupMysqlbinlog 完全恢复[TOC]# 一、安装mysql 8.0.19## 1.1https://www.modb.pro/db/509223MySQL 的全量备份、增量备份与 Binlog 时间点恢复_mysqlbinlog自动备份吗-CSDN博客文章…...
区块链技术在供应链管理中的应用与创新
在当今全球化的商业环境中,供应链管理的复杂性与日俱增。从原材料采购到最终产品交付,涉及众多环节和参与者,信息的透明度、准确性和安全性至关重要。区块链技术的出现,为供应链管理带来了全新的解决方案,正在逐步改变…...
字符指针的三道例题+算法改进
目录 一.杨氏矩阵 1.初级 2.想把下标带回来 二.字符串左旋 算法改进 三.判断是否为字符串旋转结果 算法改进 四. 3个字符函数 1.strcat 2.strncat 3.strstr 一.杨氏矩阵 数字矩阵,每行从左到右递增,每列从上到下递增,编写程序在矩…...
PostgreSQL用SQL实现俄罗斯方块
📢📢📢📣📣📣 作者:IT邦德 中国DBA联盟(ACDU)成员,10余年DBA工作经验 Oracle、PostgreSQL ACE CSDN博客专家及B站知名UP主,全网粉丝10万 擅长主流Oracle、MySQL、PG、高斯…...
如何构建简单有效的AI Agents代理?
工程技术 在过去的一年里,我们与数十个跨行业的团队合作,构建基于大型语言模型(LLM)的代理。我们发现,最成功的实现并不是使用复杂的框架或专门的库,而是采用简单、可组合的模式。 在本文中,我…...
【虚幻引擎UE5】SpawnActor生成Character实例不执行AI Move To,未初始化AIController的原因和解决方法
虚幻引擎版本:5.5.4 问题描述 刚创建的Third Person项目里,定义一个BP_Enemy蓝图,拖拽到场景中产生的实例会追随玩家,但SpawnActor产生的实例会固定不动。BP_Enemy蓝图具体设计如下: BP_Enemy的Event Graph 又定义…...
查看GPU型号、大小;CPU型号、个数、核数、内存
GPU型号、大小 nvidia-smiCPU型号 cat /proc/cpuinfo | grep model name | uniqCPU个数 cat /proc/cpuinfo | grep "physical id" | uniq | wc -lCPU核数 cat /proc/cpuinfo | grep "cpu cores" | uniqCPU内存 cat /proc/meminfo | grep MemTotal参考…...
xcode中移除安装的package dependency
有的依赖包安装之后,没有用,所以就需要把这个依赖项去掉,找了好久没有找到在哪里,最后发现在项目详情里面: 选中这一项,然后删除就可以了...
星越L_ 雨刷使用功能讲解
目录 1.向下拨动 2,向上拨动 3.调节雨刷的灵敏度 4.再次向上拨动 5.再向上 6.向内侧拨动 7.后雨刷开启 8.向外侧拨动 9.更换雨刷 1.向下拨动 雨刷单次工作 2,向上拨动 自动雨刷开启 3.调节雨刷的灵敏度 转动滚轮调节雨刷的灵敏度...
卷积神经网络 - 梯度和反向传播算法
在卷积网络中,参数为卷积核中权重以及偏置。和全连接前馈网络类似,卷积网络也可以通过误差反向传播算法来进行参数学习。本文我们从数学角度,来学习卷积神经网络梯度的推导和其反向传播算法的原理。 一、梯度:损失函数 L 关于第 …...
MATLAB—从入门到精通的第四天:函数、绘图与数学魔法
MATLAB—从入门到精通的第四天:函数、绘图与数学魔法 欢迎来到第四天的 MATLAB 奇幻之旅!今天的内容将包含 函数编写、数据搬运(导入/导出)、让数据跳舞(绘图),以及 数学咒语(代数、…...
人工智能:企业RAG方案
一、LangChain FAISS、Milvus / Weaviate介绍 在企业 RAG (Retrieval-Augmented Generation)方案中,LangChain FAISS 和 Milvus / Weaviate 都是用于向量检索(Vector Search)的核心工具。两者的核心区别在于 存储方…...
【leetcode hot 100 39】组合总和
错误解法一:每一次回溯都遍历提供的数组 class Solution {public List<List<Integer>> combinationSum(int[] candidates, int target) {List<List<Integer>> result new ArrayList<List<Integer>>();List<Integer> te…...
基于 Java 和深度学习的图像分类应用实践
前言 随着人工智能技术的飞速发展,深度学习在图像处理、自然语言处理等领域展现出强大的能力。然而,许多开发者认为深度学习只能依赖 Python 的框架(如 TensorFlow 或 PyTorch)。事实上,Java 生态也有成熟的深度学习库,如 Deeplearning4j(DL4J),适合企业级应用场景。…...
SpringMVC全局异常处理机制
异常处理机制 异常处理的两种方式: 编程式异常处理:是指在代码中显式地编写处理异常的逻辑。它通常涉及到对异常类型的检测及其处理,例如使用 try-catch 块来捕获异常,然后在 catch 块中编写特定的处理代码,或者在 f…...
基于32单片机的无人机直流电机闭环调速系统设计
标题:基于32单片机的无人机直流电机闭环调速系统设计 内容:1.摘要 本文针对无人机直流电机调速需求,设计了基于32单片机的无人机直流电机闭环调速系统。背景在于无人机应用场景不断拓展,对电机调速精度和稳定性要求日益提高。目的是开发一套高精度、响应…...
如何实现园区零碳管理?安科瑞EMS3.0推动园区低碳转型
当工业园区电费年耗超千万、碳排数据成监管红线,传统“拉闸限电”式管理已无法应对双碳倒计时——如何让光伏、储能、充电桩“听懂指令”,让每一度电创造3倍价值?187*210*98*782 一、零碳园区管理的三大痛点 1. 能源错配严重:风…...
Python Django入门(创建其他网页)
在本章中,你将学习如何使用 Django(http://djangoproject.com/ )来开发一个名为“学习笔记”(Learning Log)的项目,这是一个在线日志系统,让你能够记录所学习的有关特定主题的知识。 我们将为这…...
