分布式协同 - 分布式事务_2PC 3PC解决方案

news2024/12/23 16:10:48

文章目录

  • 导图
  • Pre
  • 2PC(Two-Phase Commit)协议
    • 准备阶段
    • 提交阶段
      • 情况 1:只要有一个事务参与者反馈未就绪(no ready),事务协调者就会回滚事务
      • 情况 2:当所有事务参与者均反馈就绪(ready)消息时,事务协调者会提交(commit)事务
  • 3PC(Three-Phase Commit)协议
    • 3PC的三个阶段
    • 3PC 的流程
  • 3PC 和 2PC 的主要区别
    • 1. 阶段数量不同
    • 2. 容错能力
    • 3. 协议的安全性与复杂性
    • 4. 阻塞问题
    • 5. 事务资源锁定
    • 6. 性能开销
  • 总结

在这里插入图片描述

导图

在这里插入图片描述


Pre

分布式协同 - 分布式事务一二事儿DTP 定义了分布式事务的处理模型,可以针对这个模型提出分布式事务的解决方案,2PC 就是其中一种。

2PC 的全称为两阶段提交(Two Phase Commitment Protocol),是 DTP 模型的最佳实践,解决了在分布式服务或数据库场景下,同一事务对多个节点进行操作的数据一致性问题。

2PC 在一定程度上遵守 ACID 理论的刚性事务的要求,保证了强一致性。 2PC 中有两个概念,

  • 一个是事务协调者,对应 DTP 模型中的事务管理器,用来协调事务,所有事务什么时候准备好、什么时候可以提交都由它来协调和管理;
  • 另一个是事务参与者,对应 DTP 模型中的资源管理器,主要负责处理具体事务、管理需要处理的资源。例如事务参与者可以处理订票业务,扣款业务。

2PC(Two-Phase Commit)协议

+-----------------+                +------------------+                +-----------------+
|   Transaction   |                |   Coordinator    |                |   Participant   |
|     Client      |                |       Node       |                |       Node      |
+-----------------+                +------------------+                +-----------------+
        |                                  |                                   |
        |----------(1) Request Start ------>                                   |
        |                                  |                                   |
        |                                  | --------------(2) Prepare-------->|
        |                                  |                                   |
        |                                  | <--------- (3) Acknowledge ------|
        |                                  |                                   |
        |                                  |                                   |
        |                                  | --------------(4) Commit--------->|
        |                                  |                                   |
        |                                  | <--------- (5) Acknowledge ------|
        |                                  |                                   |
        |                                  |                                   |
        |                                (End)                               (End)

准备阶段

第一阶段(准备阶段):如下图 所示

在这里插入图片描述

事务协调者(事务管理器)给每个事务参与者(资源管理器)发送准备(prepare)消息,目的是询问大家是不是都准备好了,马上就要执行事务了。事务参与者会根据自身业务和资源情况进行检查,然后给出反馈。检查过程根据业务内容的不同而不同,例如订票业务需要检查是否有剩余票、扣款业务需要检查余额是否足够。

只有检查通过,才能返回就绪(ready)信息。否则,事务将终止,并且等待下次询问。由于检查过程需要完成一些操作,因此需要写 redo 日志和 undo 日志,以便事务失败重试,或者失败回滚时使用。


提交阶段

第二阶段(提交阶段):如下图所示
在这里插入图片描述

如果事务协调者接收到事务参与者检查失败或者超时的消息,会给其发送回滚(rollback)消息,否则发送提交(commit)消息。

情况 1:只要有一个事务参与者反馈未就绪(no ready),事务协调者就会回滚事务

  • a) 事务协调者向所有事务参与者发出回滚请求。
  • b) 事务参与者使用第一阶段中 undo 日志里的信息执行回滚操作,并且释放整个事务期间占用的资源。
  • c) 各事务参与者向事务协调者反馈应答(ack)消息,表示完成操作。
  • d) 事务协调者接收到所有事务参与者反馈的应答消息,即完成了事务回滚。

情况 2:当所有事务参与者均反馈就绪(ready)消息时,事务协调者会提交(commit)事务

  • a) 事务协调者向所有事务参与者发出正式提交事务的请求。
  • b) 事务参与者执行提交(commit)操作,并释放整个事务期间占用的资源。
  • c) 各事务参与者向事务协调者反馈应答(ack)消息,表示完成操作。
  • d) 事务协调者接收到所有事务参与者反馈的应答(ack)消息,即完成了事务提交。

3PC(Three-Phase Commit)协议

3PC(三阶段提交)是分布式事务中的一种协议,旨在解决2PC协议中的阻塞问题。3PC协议通过在2PC的基础上增加了一个阶段,增加了事务的容错能力,从而避免了协调者或参与者崩溃时可能发生的阻塞现象。

3PC的三个阶段

  1. CanCommit 阶段(询问阶段)

    • 协调者向所有参与者发送“CanCommit”请求,询问它们是否可以提交事务。
    • 参与者收到请求后,会检查本地的事务状态。如果没有冲突,且可以提交,它们就返回“Ready”响应;如果事务存在问题,则返回“No”响应,表示无法提交。
  2. PreCommit 阶段(预提交阶段)

    • 如果所有参与者都返回了“Ready”,协调者就会向所有参与者发送“PreCommit”命令,表示准备提交事务,并让它们锁定相关资源。
    • 参与者在接收到“PreCommit”命令后,执行事务的预提交操作并返回确认。
  3. DoCommit 阶段(提交阶段)

    • 如果所有参与者都返回了预提交确认(“PreCommit”),协调者会向所有参与者发送“DoCommit”命令,正式提交事务。
    • 参与者接收到“DoCommit”命令后,执行提交操作,事务完成。

3PC 的流程

+-----------------+                +------------------+                +-----------------+
|   Transaction   |                |   Coordinator    |                |   Participant   |
|     Client      |                |       Node       |                |       Node      |
+-----------------+                +------------------+                +-----------------+
        |                                  |                                   |
        |----------(1) Request Start ------>                                   |
        |                                  |                                   |
        |                                  |  --------(2) CanCommit --------->|
        |                                  |                                   |
        |                                  | <----------(3) Ready/No --------|
        |                                  |                                   |
        |                                  |  --------(4) PreCommit --------->|
        |                                  |                                   |
        |                                  | <----------(5) PreCommitAck -----|
        |                                  |                                   |
        |                                  |  --------(6) DoCommit ---------->|
        |                                  |                                   |
        |                                  | <----------(7) DoCommitAck ------|
        |                                  |                                   |
        |                                (End)                               (End)

3PC 和 2PC 的主要区别

1. 阶段数量不同

  • 2PC 有两个阶段:

    1. Prepare: 协调者询问参与者是否能提交事务。
    2. Commit/Abort: 根据参与者的响应,协调者决定是否提交或回滚事务。
  • 3PC 有三个阶段:

    1. CanCommit: 协调者询问参与者是否准备提交。
    2. PreCommit: 协调者发送预提交命令,参与者准备提交并锁定资源。
    3. DoCommit: 协调者发送最终提交命令,事务正式提交。

2. 容错能力

  • 2PC 在协调者或参与者崩溃时可能会出现阻塞。例如,如果协调者崩溃后,参与者不知道是应该提交还是回滚,系统可能会陷入阻塞状态,无法继续执行。
  • 3PC 增加了一个额外的阶段(PreCommit),并且在每个阶段都有明确的响应协议,可以减少系统在协调者或参与者崩溃时的阻塞风险。3PC通过引入超时机制预提交锁定,有效减少了数据不一致和系统停滞的概率。

3. 协议的安全性与复杂性

  • 2PC 协议相对简单,但存在阻塞问题,且在部分情况下(例如,协调者崩溃),事务无法保证最终一致性。
  • 3PC 协议在设计上更加复杂,通过引入预提交阶段,提高了系统的容错能力,但也增加了协议的开销和实现的复杂性。

4. 阻塞问题

  • 2PC 存在阻塞问题,特别是在协调者或参与者崩溃的情况下,事务无法继续或回滚,可能会导致长时间的停滞。
  • 3PC 通过引入额外的阶段,并要求所有参与者在每个阶段都给予明确的响应,避免了阻塞的可能性。当协调者或参与者崩溃时,系统会通过超时机制自动恢复,减少了长时间的停滞。

5. 事务资源锁定

  • 2PC 中,事务资源在提交后才被释放,可能会因为参与者的延迟或崩溃导致长时间的资源占用。
  • 3PC 引入了预提交阶段,在PreCommit时就锁定了资源并确保它们在提交前是有效的,因此能更有效地管理资源的占用。

6. 性能开销

  • 2PC 因为只有两个阶段,协议简单,性能相对较好,但当系统出现故障时,性能和一致性会受到较大影响。
  • 3PC 虽然增加了一个阶段,但引入了更多的容错机制,可能会有稍微的性能开销,但能在故障恢复时保持更高的可用性。

总结

特性2PC (Two-Phase Commit)3PC (Three-Phase Commit)
阶段数量2个阶段:Prepare(准备阶段)和Commit/Abort(提交/回滚阶段)3个阶段:CanCommit(询问阶段)、PreCommit(预提交阶段)、DoCommit(提交阶段)
协议设计基于两阶段协议,协议简单但容易导致阻塞问题基于三阶段协议,增加了预提交阶段,减少了阻塞问题
阻塞问题存在阻塞问题,特别是当协调者或参与者崩溃时,系统可能无法继续通过引入PreCommit阶段,减少了崩溃时的阻塞问题,避免了长时间停滞
协调者崩溃的处理协调者崩溃后,参与者不确定事务是提交还是回滚,导致阻塞由于引入了CanCommit和PreCommit阶段,协调者崩溃后的恢复能力较强,减少了阻塞的可能
参与者崩溃的处理如果参与者在Prepare阶段崩溃,事务可能无法提交在PreCommit阶段,参与者能锁定资源,如果崩溃,系统能更好恢复,减少了不一致情况
事务提交的一致性保证一致性,但有可能因为协调者或参与者崩溃导致无法提交或回滚在多数情况下保证一致性,并且通过额外阶段减少了崩溃带来的影响
资源管理资源管理依赖于Prepare阶段,协调者发出提交或回滚命令资源管理通过PreCommit阶段锁定资源,协调者发送最终提交命令
性能开销由于只有两个阶段,性能较高,但可能因为故障导致较长的延迟增加了一个阶段,性能会有一定的开销,但能有效减少阻塞问题
协议复杂性协议较简单,实现起来相对容易,但缺乏容错能力协议更复杂,要求在协议层面上有更多的容错设计和实现
适用场景适用于对一致性要求较高的场景,如分布式数据库事务适用于对高可用性和容错性要求较高的场景,尤其是需要更好恢复能力的分布式系统
超时处理通常需要外部机制(如超时检测)来处理超时问题协议本身提供了对超时和崩溃的处理机制,有更强的容错能力
  • 2PC 由于其简单的设计,适用于一些不涉及复杂容错的场景,但它容易因为崩溃或故障导致阻塞问题,事务可能无法继续进行。
  • 3PC 在 2PC 的基础上增加了一个阶段,提升了系统容错能力,减少了由于协调者或参与者崩溃导致的阻塞,但相应地增加了协议的复杂度和性能开销。

在选择2PC还是3PC时,需要根据具体应用场景的容错要求、性能需求以及系统复杂度进行权衡。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2264311.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ubuntu 如何重装你的apt【apt-get报错: symbol lookup error/undefined symbol】

副标题:解决error:apt-get: symbol lookup error: /lib/x86_64-linux-gnu/libapt-private.so.0.0: undefined symbol: _ZNK13pkgTagSection7FindULLENS_3KeyERKy, version APTPKG_6.0 文章目录 问题描述报错分析解决方案:重装你的apt1、查看你的ubuntu版本2、下载适配你的ap…

RK3588 , mpp硬编码yuv, 保存MP4视频文件.

RK3588 , mpp硬编码yuv, 保存MP4视频文件. ⚡️ 传送 ➡️ Ubuntu x64 架构, 交叉编译aarch64 FFmpeg mppRK3588, FFmpeg 拉流 RTSP, mpp 硬解码转RGBRk3588 FFmpeg 拉流 RTSP, 硬解码转RGBRK3588 , mpp硬编码yuv, 保存MP4视频文件.

纯血鸿蒙APP实战开发——动态注册字体案例

介绍 本示例介绍利用上传下载模块和注册自定义字体模块实现从网络上下载字体并注册应用字体的功能&#xff0c;该场景多用于由特殊字体要求的场景。 效果图预览 使用说明 进入本案例页面后&#xff0c;可点击下方按钮切换字体。目前仅提供了思源宋体的注册&#xff0c;第一次…

Oracle中间件 SOA之 OSB 12C服务器环境搭建

环境信息 服务器基本信息 如下表&#xff0c;本次安装总共使用1台服务器&#xff0c;具体信息如下&#xff1a; App1服务器 归类 APP服务器 Ip Address 172.xx.30.xx HostName appdev01. xxxxx.com Alias appdev01 OSB1服务器 归类 OSB服务器 Ip Address 172.xx3…

数据结构---------二叉树前序遍历中序遍历后序遍历

以下是用C语言实现二叉树的前序遍历、中序遍历和后序遍历的代码示例&#xff0c;包括递归和非递归&#xff08;借助栈实现&#xff09;两种方式&#xff1a; 1. 二叉树节点结构体定义 #include <stdio.h> #include <stdlib.h>// 二叉树节点结构体 typedef struct…

前置知识补充—JavaScript

JavaScript 简介 JavaScript 是什么 JavaScript (简称 JS), 是⼀个脚本语⾔, 解释型或即时编译型的编程语⾔. 虽然它是作为开发Web⻚⾯的脚本语⾔⽽出名&#xff0c;但是它也被⽤到了很多⾮浏览器环境中 HTML&#xff1a; ⽹⻚的结构 CSS&#xff1a; …

Mac上详细配置java开发环境和软件(更新中)

文章目录 概要JDK的配置JDK下载安装配置JDK环境变量文件 Idea的安装Mysql安装和配置Navicat Premium16.1安装安装Vscode安装和配置Maven配置本地仓库配置阿里云私服Idea集成Maven Cpolar快速入门 概要 这里使用的是M3型片 14.6版本的Mac 用到的资源放在网盘 链接: https://pan…

第二十六周机器学习笔记:PINN求正反解求PDE文献阅读——正问题

第二十六周周报 摘要Abstract文献阅读《Physics-informed neural networks: A deep learning framework for solving forward and inverse problems involving nonlinear partial differential equations》1. 引言2. 问题的设置3.偏微分方程的数据驱动解3.1 连续时间模型3.1.1 …

米思奇图形化编程之ESP32控制LED灯闪烁方案实现

目录 一、项目概述 二、硬件准备 三、硬件连接 四、软件编程 五、验证效果 六、总结 一、项目概述 本项目使用米思奇图形化编程环境&#xff0c;编写micropython软件代码&#xff0c;实现了控制ESP32开发板上LED灯闪烁效果。该项目可为后续更复杂的物联网项目打下基础。…

完全离线使用,效率直接拉满

现在越来越多的人使用OCR软件来提高自己的工作效率&#xff0c;今天给大家推荐一款电脑端的文字识别工具&#xff0c;对比以往的软件来说&#xff0c;功能更加丰富全面。 Umi-OCR 美术、舞蹈、音乐 打开软件之后需要安装一下。 软件主要有截图OCR识别、批量OCR识别、批量文档识…

CSDN外链失效3:

参考我之前的博客&#xff1a; 外链失效博客1&#xff1a;随想笔记1&#xff1a;CSDN写博客经常崩溃&#xff0c;遇到外链图片转存失败怎么办_csdn外链图片转存失败-CSDN博客 外链失效博客2&#xff1a;网络随想2&#xff1a;转语雀_md格式转语雀lake格式-CSDN博客 markdown…

Java 中的字符串

目录 Java 中的字符串字符串的创建字符串的比较字符串的拼接如何定义一个空的字符串 Java 中的字符串 字符串的创建 在 Java 中&#xff0c;可以通过以下几种方式创建字符串&#xff1a; 1.使用字符串字面量&#xff1a; String str "Hello, World!";2.使用 new…

U盘结构损坏且无法访问:原因、恢复方案与预防措施

U盘结构损坏现象描述 U盘&#xff0c;这一小巧便捷的存储设备&#xff0c;在日常工作和学习中扮演着重要角色。然而&#xff0c;当U盘出现结构损坏且无法访问时&#xff0c;用户往往会陷入焦虑与困惑。具体表现为&#xff0c;将U盘插入电脑后&#xff0c;系统无法识别U盘&…

basic_ios及其衍生库(附 GCC libstdc++源代码)

basic_ios及其衍生库(附 GCC libstdc源代码) 我们由这张图展开我们的讨论 对于Date对象&#xff0c;只有实现了<<重载到输出流才可以插入到stringstream ss中 现在我有疑问stringstream是怎么做到既能输出又能输入的&#xff1f; 而且为什么stringstream对象能传给ostre…

【开源库 | minizip】Linux(Ubuntu18.04)下,minizip的编译、交叉编译

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; ⏰发布时间⏰&#xff1a; 2024-12-20 …

Gin-vue-admin(1):环境配置和安装

目录 环境配置如果443网络连接问题&#xff0c;需要添加代理服务器 后端运行前端运行 环境配置 git clone https://gitcode.com/gh_mirrors/gi/gin-vue-admin.git到server文件目录下 go mod tidygo mod tidy 是 Go 语言模块系统中的一个命令&#xff0c;用于维护 go.mod 文件…

java: 无效的目标发行版: xx

java: 无效的目标发行版: xx 背景java: 无效的目标发行版: xx 在 Intellij 的修复 背景 这里单独针对Intellij开发工具对 “java: 无效的目标发行版: xx”错误的修复。 java: 无效的目标发行版: xx 在 Intellij 的修复 同一台电脑使用多个JDK的时候容易出现在运行程序时容易…

vscode+编程AI配置、使用说明

文章目录 [toc]1、概述2、github copilot2.1 配置2.2 使用文档2.3 使用说明 3、文心快码&#xff08;Baidu Comate&#xff09;3.1 配置3.2 使用文档3.3 使用说明 4、豆包&#xff08;MarsCode&#xff09;4.1 配置4.2 使用文档4.3 使用说明 5、通义灵码&#xff08;TONGYI Lin…

leetcode-80.删除有序数组的重复项II-day12

总结&#xff1a;不必过于死磕一道题目&#xff0c;二十分钟没做出来就可参考题解

Docker 入门:如何使用 Docker 容器化 AI 项目(一)

引言 在人工智能&#xff08;AI&#xff09;项目的开发和部署过程中&#xff0c;环境配置和依赖管理往往是开发者遇到的挑战之一。开发者通常需要在不同的机器上运行同样的代码&#xff0c;确保每个人使用的环境一致&#xff0c;才能避免 “在我的机器上可以运行”的尴尬问题。…