分布式事务三阶段协议
分布式事务的三阶段分别是准备阶段、预提交阶段和提交 / 回滚阶段,以下是详细介绍:
三阶段提交协议可以理解为两阶段提交协议的改良版,是在协调者和参与者中都引入超时机制,并且把两阶段提交协议的第一个阶段分成了两步: 询问,然后再锁资源,最后真正提交。
两阶段提交协议最早是分布式事务的专家Jim Gray在1978年的一篇文章Notes on Database Operating Systems中提及。两阶段提交协议可以保证数据的强一致性,即保证了分布式事务的原子性:所有结点要么全做要么全不做。许多分布式关系型数据管理系统采用此协议来完成分布式事务。它是协调所有分布式原子事务参与者,并决定提交或取消(回滚)的分布式算法。同时也是解决一致性问题的算法。该算法能够解决很多的临时性系统故障(包括进程、网络节点、通信等故障),被广泛地使用。但是,它并不能够通过配置来解决所有的故障,在某些情况下它还需要人为的参与才能解决问题。两阶段提交协议存在的问题是,协调者在某些时刻如果失败了, 整个事务就会阻塞。于是Skeen发布了"NonBlocking Commit Protocols" (1981)这篇论文,论文指出在一个分布式的事务里面, 需要一个三阶段的提交协议来避免在两阶段提交中存在的阻塞问题。
准备阶段(CanCommit)
- 事务询问:协调者向所有参与者发送包含事务内容的
CanCommit请求,询问是否可以执行事务提交操作,并开始等待各参与者的响应。 - 各参与者响应:参与者收到
CanCommit请求后,会根据自身情况判断是否可以执行事务。如果参与者认为可以执行事务,则返回Yes响应,表示它准备好执行事务;如果参与者无法执行事务,例如因为资源不足、数据冲突等原因,则返回No响应。 -
如果参与者能够执行任务,那么返回协调者
Yes状态
参与者不能执行任务,返回No,结束事务
预提交阶段(PreCommit)
- 执行事务操作:如果协调者在准备阶段收到了所有参与者的
Yes响应,那么它会向所有参与者发送PreCommit请求,进入预提交阶段。参与者在收到PreCommit请求后,会执行事务操作,但不会真正提交事务,而是将事务操作结果记录到本地的事务日志中,并释放部分事务资源,但仍保持对事务的锁定状态,以便后续可能的提交或回滚操作。 - 响应预提交结果:参与者执行完事务操作后,会向协调者发送
Ack响应,表示事务操作已经执行完成。如果参与者在执行事务操作过程中出现了问题,例如数据库故障、网络问题等,导致无法执行事务操作,那么它会向协调者发送No响应,并回滚已经执行的事务操作。 - yes
-


提交 / 回滚阶段(DoCommit/Abort)
- 提交事务:如果协调者在预提交阶段收到了所有参与者的
Ack响应,那么它会向所有参与者发送DoCommit请求,通知参与者正式提交事务。参与者在收到DoCommit请求后,会将事务正式提交到数据库中,并释放所有事务资源,完成事务操作。 - 回滚事务:如果协调者在准备阶段或预提交阶段收到了任何参与者的
No响应,或者在等待参与者响应的过程中出现了超时等情况,那么它会向所有参与者发送Abort请求,通知参与者回滚事务。参与者在收到Abort请求后,会根据本地事务日志中的记录,回滚已经执行的事务操作,并释放所有事务资源。


三阶段提交协议相对于二阶段提交协议,增加了预提交阶段,使得分布式事务的提交过程更加稳健,能够在一定程度上避免数据不一致的问题,但它也增加了事务的复杂性和性能开销。

在分布式系统中,为了协调多个节点共同参与的事务,通常会采用三阶段提交协议(3PC)。关于三阶段提交协议,以下哪个描述是正确的?
A. 三阶段提交协议只包括准备提交(Prepare)和提交(Commit)两个阶段。
B. 在三阶段提交协议中,如果有一个参与者回复不能提交(No),则事务协调者会立即中止事务。
C. 三阶段提交协议可以确保在所有参与者都成功提交事务之前,任何参与者都不会单独提交事务。
D. 三阶段提交协议中的第三阶段是向所有参与者发送预提交(PreCommit)请求。
正确答案:
C
参考
分布式事务讲解之CAP,2PC,3PC,TCC,分布式锁 - 上善若泪 - 博客园 (cnblogs.com)
相关文章:
分布式事务三阶段协议
分布式事务的三阶段分别是准备阶段、预提交阶段和提交 / 回滚阶段,以下是详细介绍: 三阶段提交协议可以理解为两阶段提交协议的改良版,是在协调者和参与者中都引入超时机制,并且把两阶段提交协议的第一个阶段分成了两步: 询问&am…...
LLaMA-Factory|微调大语言模型初探索(4),64G显存微调13b模型
上篇文章记录了使用lora微调deepseek-7b,微调成功,但是微调llama3-8b显存爆炸,这次尝试使用qlora微调HQQ方式量化,微调更大参数体量的大语言模型,记录下来微调过程,仅供参考。 对过程不感兴趣的兄弟们可以直…...
常用高压缩率的视频容器格式,并进行大比例压缩
常用的高压缩率视频容器格式,包括*.mp4 、*.mkv、*.webM等。 容器格式本身并不直接决定压缩率,而是取决于容器中所使用的视频编码格式等因素。不过,在常见的视频容器格式中,一些容器在搭配特定编码格式时,通常能表现出较高的压缩效率,以下是相关介绍: 1 MKV格式 …...
代码编译(词法义)
1.预处理 (Preprocessing): 在这个阶段,编译器会处理所有以 # 开头的指令,如 #include、#define 等。它会把头文件的内容插入到源代码中,进行宏替换等预处理操作,生成一个纯净的代码文件。 3.词法分析 (Lexical Analy…...
android,flutter 混合开发,pigeon通信,传参
文章目录 app效果native和flutter通信的基础知识1. 编解码器 一致性和完整性,安全性,性能优化2. android代码3. dart代码 1. 创建flutter_module2.修改 Android 项目的 settings.gradle,添加 Flutter module3. 在 Android app 的 build.gradl…...
at32f403a rt thread led基础bsp工程测试
1.led工程官方bsp使用 导出一个独立的AT32F403A的BSP工程 下载RTT源代码 gitee更新较慢 https://gitee.com/rtthread/rt-thread github版本更新最新 https://github.com/RT-Thread/rt-thread. 切换到V5.1.0分支(使用一个发布版本可以避免不必要的bug) 导出一个独立的AT32BSP…...
DeepSeek写贪吃蛇手机小游戏
DeepSeek写贪吃蛇手机小游戏 提问 根据提的要求,让DeepSeek整理的需求,进行提问,内容如下: 请生成一个包含以下功能的可运行移动端贪吃蛇H5文件: 要求 蛇和食物红点要清晰,不超过屏幕外 下方有暂停和重新…...
【好玩的工具和命令】 ASCII 艺术生成工具: figlet
figlet 是一款用于生成 ASCII 艺术文字的工具,支持多种字体样式。它能将输入的文本转换为由字符组成的大型字母图案,广泛应用于命令行环境下的标题展示或装饰。 核心功能 生成 ASCII 文字艺术:将普通文本转化为大号的、由字符构成的艺术字…...
工具--安川伺服故障代码
上传一下安川伺服故障代码,后续结合实际维修经验,逐个整理分析,绝对超出手册经验 故障代码 故障描述 a.020/a.02 用户参数和数检查异常 1 a.021/a.02 参数格式化异常 1 a.022/a.02 系统参数和数检查异常 1 a.023/a.02 参数密码异常…...
车载软件架构 --- OEM主机厂如何打入软件供应商内部?
我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 简单,单纯,喜欢独处,独来独往,不易合同频过着接地气的生活,除了生存温饱问题之外,没有什么过多的欲望,表面看起来很高冷,内心热情,如果你身…...
AI 编程助手 cursor的系统提示词 prompt
# Role 你是一名极其优秀具有10年经验的产品经理和精通java编程语言的架构师。与你交流的用户是不懂代码的初中生,不善于表达产品和代码需求。你的工作对用户来说非常重要,完成后将获得10000美元奖励。 # Goal 你的目标是帮助用户以他容易理解的…...
Matlab写入点云数据到Rosbag
最近有需要读取一个点云并做处理后,重新写回rosbag。网上有很多读取的教程,但没有写入。自己写入时也遇到了很多麻烦,踩了一堆坑进行记录。 1. rosbag中一个lidar的msg有哪些信息? 通过如下代码,先读取一个rosbag的l…...
业务流程相关的权威认证和培训有哪些
业务流程的认证和培训种类繁多,旨在帮助专业人士掌握业务流程管理 (BPM) 的知识和技能,从而提升个人职业发展和组织运营效率。下面分别介绍: 一、 业务流程认证和培训的种类 业务流程的认证和培训可以大致分为以下几类,涵盖了不…...
基于Spring Boot的兴顺物流管理系统设计与实现(LW+源码+讲解)
专注于大学生项目实战开发,讲解,毕业答疑辅导,欢迎高校老师/同行前辈交流合作✌。 技术范围:SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容:…...
【算法系列】荷兰国旗问题:三指针法原地排序
一、题目(leetcode75 颜色分类 --三分数组) 二、思路 算法核心:三指针分治策略 该问题被称为“荷兰国旗问题”(Dutch National Flag Problem),由计算机科学家Edsger Dijkstra提出。其核心思想是通过三个指针将数组划分为三个区…...
DeepSeek R1本地+私有云版医疗AI部署开发成功案例技术剖析
1. 引言 1.1 研究背景与意义 随着科技的飞速发展,人工智能(AI)在医疗领域的应用正逐渐成为推动医疗行业变革的重要力量。近年来,医疗 AI 取得了显著的进展,从疾病诊断、药物研发到医疗管理等各个环节,AI 技术都展现出了巨大的潜力。它能够处理和分析海量的医疗数据,为…...
ARM64 Trust Firmware [五]
本章介绍 ATF 中的 Runtime Service 是如何定义和被调用的。 要了解 SMC,必须从 SMC 指令本身开始,其指令如下图: 指令格式为:SMC #<imm>,从官方文档了解到该指令只能在 EL1 以及更高的异常等级上调用ÿ…...
rkipc main.c 中 rk_param_init函数分析
rk_param_init函数 这个函数是用来读取配置文件进行参数配置 这个函数在 luckfox-pico/project/app/rk_smart_door/smart_door/common/uvc/param/param.c 中 这个函数在main函数中被调用 //通过-c 配置文件路径 把配置文件传进来 case c:rkipc_ini_path_ optarg;//调用&am…...
正确清理C盘空间
一.系统清理 正确清理C盘空间主要是删除不需要的文件和应用程序,以释放磁盘空间。以下是一些常用的方法: 删除临时文件:在Windows搜索框中输入“%temp%”,打开临时文件夹,将其中的文件全部删除。 清理回收站…...
http代理IP怎么实现?如何解决代理IP访问不了问题?
HTTP代理是一种网络服务,它充当客户端和目标服务器之间的中介。当客户端发送请求时,请求首先发送到代理服务器,然后由代理服务器转发到目标服务器。同样,目标服务器的响应也会先发送到代理服务器,再由代理服务器返回给…...
模型最终版-我可以发论文了
训练日志 指标 含义 评价Train Loss训练集上的总损失值(预测损失 λ先验损失 McMillan软约束)初始值较高,正常Val Loss验证集上的总损失值R决定系…...
医疗可穿戴设备边缘RAG技术:能耗优化与硬件加速
1. 医疗可穿戴设备中的边缘RAG技术挑战与机遇在智能医疗设备快速发展的今天,可穿戴医疗设备正从简单的数据采集向智能化诊疗辅助演进。我曾在多个医疗AI项目中深刻体会到,如何在资源受限的边缘设备上实现高效的知识检索与生成,是制约个性化医…...
深入理解 Transformer:从数据流动看模型架构
1 实用案例 1.1 表格样式生成 本示例用于生成包含富文本样式与单元格背景色的Word表格文档。 模板内容: 渲染代码: # python-docx-template/blob/master/tests/comments.py from docxtpl import DocxTemplate, RichText # data: python-docx-template/bl…...
Linux bridge 在终端路由器中的实际应用——路由模式、桥接模式与 VLAN 桥接
Linux bridge 是终端路由器中最基础的网络组件之一——所有 LAN 口和 WiFi 接口能互通,就是因为它们都加在同一个 bridge 里。本文讲清 bridge 在路由模式、桥接模式、VLAN 桥接中的不同用法,以及实际开发中的注意事项。 1. Bridge 是什么 简单说&#…...
脉冲神经网络开发指南:从原理到医疗影像实战
1. 脑启发式AI开发指南作为一名在机器学习领域工作多年的开发者,我见证了传统神经网络与脑科学融合带来的范式转变。去年参与医疗影像分析项目时,采用脉冲神经网络(SNN)将CT扫描识别准确率提升了12%,这让我意识到生物神…...
RTX 30系显卡救星:保姆级教程搞定Windows下TensorFlow 2.4.0 GPU环境(含Pillow版本避坑)
RTX 30系显卡救星:保姆级教程搞定Windows下TensorFlow 2.4.0 GPU环境(含Pillow版本避坑) 最近在帮同事配置TensorFlow 2.4.0 GPU环境时,发现30系显卡用户遇到的坑比想象中多得多。特别是那些看似莫名其妙的报错,比如&q…...
PPTAgent终极指南:10分钟掌握AI智能演示文稿生成
PPTAgent终极指南:10分钟掌握AI智能演示文稿生成 【免费下载链接】PPTAgent An Agentic Framework for Reflective PowerPoint Generation 项目地址: https://gitcode.com/gh_mirrors/pp/PPTAgent 你是否曾为制作演示文稿而烦恼?从整理文档内容到…...
LIME模型可解释性:原理、实战与优化技巧
1. 理解模型可解释性的重要性 在机器学习项目实践中,我们常常会遇到一个困境:模型预测效果很好,但完全不知道它为什么做出这样的决策。三年前我接手一个医疗诊断项目时,随机森林模型在测试集上达到了94%的准确率,但当医…...
人体活动识别技术:算法评估与工程实践
1. 项目背景与核心挑战人体活动识别(Human Activity Recognition, HAR)是机器学习在可穿戴设备和智能感知领域的重要应用场景。我们经常需要从加速度计、陀螺仪等传感器数据中自动识别行走、跑步、坐卧等日常活动。这个任务看似简单,但在实际…...
Playwright实战-在gitlab ci环境运行自动化测试
简介:CI/CD持续集成和持续部署是确保代码质量和快速交付的关键步骤。本文详细介绍了如何在GitLab CI环境中配置和运行Playwright测试。 1. 前置条件 开始之前,请确保满足以下前提条件: • Playwright测试可以在本地环境中运行正常 • Gitla…...
