两阶段提交进阶

2024-08-31 19:04
文章标签 进阶 提交 阶段

本文主要是介绍两阶段提交进阶,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

## 两阶段提交之进阶

 

上一节我们讲了,两阶段提交逻辑上的表现,其实较为肤浅,并且偏向理论,可能大家都能看懂,但是如果放入实际的mysql应用中并联系事务和日志进行分析,又会怎么样呢?

 

这次就专门分析==两阶段提交在mysql更新操作中的必要性==;(定语加的有够多的🏋️‍♂️);

 

既然在mysql中,那必然是要知道mysql的更新操作是如何进行的,才能分析两阶段提交为何必要;

 

### mysql更新操作

 

对于一个**单体数据库**中,一个简单的mysql操作通常会分为:

 

> 1.解析sql语句并进行优化;

>

> 2.开始事务

>

> 3.加锁,对更新涉及到的数据加锁

>

> 4.执行更新操作并将操作记录到日志中,以支持回滚和恢复

>

> 5.提交事务,释放锁,返回结果;

 

 

 

可以看到在这过程中对于更新数据以及日志的操作都是在事务范围内进行的;

 

接下来分析日志在这个过程中的变化:

 

1. **二进制日志(Binary Log)的记录**:MySQL会将执行的更新操作记录到二进制日志中,这包括对数据的插入、更新和删除操作。二进制日志记录在事务提交之前。**Binlog通常用于数据的备份和复制,以及在主从复制架构中用于数据同步**。

2. **Redo日志的生成**:MySQL会生成Redo日志,记录**已经提交的事务对数据的修改**。Redo日志用于数据库的崩溃恢复,在数据库重启时,MySQL会根据Redo日志将已提交的事务重新应用到数据库中,确保数据的一致性。称为**重做日志**

3. **Undo日志的生成**:在事务进行过程中,MySQL会生成Undo日志,记录**事务对数据的修改前的状态**(记录了事务对数据库所做的修改的逆操作)。Undo日志用于事务的回滚操作,在事务回滚时,MySQL会根据Undo日志将数据恢复到事务开始之前的状态。称为**撤销日志**

 

我们接着分析,**如果使用两阶段提交协议**那么==对于一个分布式的数据库进行更新操作时,应该按照怎么样的顺序执行呢==

 

**在准备阶段**

 

- 协调者节点向所有参与者节点发送Prepare请求,要求它们准备提交事务。

- 参与者节点执行更新操作的准备工作,预留资源、写入Redo日志和Undo日志等,并向协调者节点发送准备就绪的响应。

 

如果没有两阶段提交,一旦在提交阶段发生了故障,可能会导致一些参与者节点已经准备好提交事务,而另一些参与者节点却无法准备就绪。这种情况下,数据可能会处于不一致的状态,从而破坏了数据的一致性和可靠性。

 

**crash阶段**(出现错误):

 

- 在Prepare阶段之后,如果系统在提交事务之前发生了崩溃或者故障,就会进入Crash阶段。

- 在Crash阶段,系统会通过Redo日志和Undo日志来进行故障恢复。

- 通过Redo日志,系统可以重新应用已经提交的事务对数据的修改,以确保数据的持久性。

- 通过Undo日志,系统可以撤销未提交的事务对数据的修改,以确保数据的一致性。

 

(在这个过程中,其实redo和undo作用和单体数据库作用是一样的,都是维持单体数据库的持久性和一致性);

 

如果没有两阶段提交,一旦在提交阶段发生了故障,可能会导致数据的更新操作部分应用到了数据库中,而另一部分未能成功应用。这种情况下,数据库可能会处于不一致的状态,从而破坏了数据的一致性和可靠性。

 

成功的话:第二阶段

 

**commit阶段**

 

- 在Commit阶段,事务会被提交,即所有的数据修改操作将被应用到数据库中。

- 在分布式环境中,可能需要将Commit请求发送给协调者节点,并等待协调者节点将Commit请求发送给各个参与者节点。

- 只有当所有参与者节点都成功提交了事务后,事务才会被视为成功提交,否则事务将被回滚。

- 在事务成功提交后,系统会确保相应的Redo日志、Undo日志和Binlog记录被正确地写入到持久化存储中,以保证数据的持久性和一致性。

 

如果没有两阶段提交,可能会导致已经提交的事务对数据的修改丢失,或者未提交的事务对数据的修改被错误地应用到了数据库中。这种情况下,数据库可能会处于不一致的状态。

 

 

 

### 扩展知识点

 

其实两阶段提交还有一个重要作用,**防止半提交发生时造成的redo日志和binlog日志不统一**

 

例:

 

![image-20240417212833412](https://i-blog.csdnimg.cn/blog_migrate/62e21d812d0382f6bf4c19e0b09c7404.png)

 

整个过程:

 

![image-20240417212933166](https://i-blog.csdnimg.cn/blog_migrate/88da41e015414e352b597c448dacb8f6.png)

 

从图中可看出,事务的提交过程有两个阶段,就是**将 redo log 的写入拆成了两个步骤:prepare 和 commit,中间再穿插写入binlog**,具体如下:

 

- **prepare 阶段**:将 XID(内部 XA 事务的 ID) 写入到 redo log,同时将 redo log 对应的事务状态设置为 prepare,然后将 redo log 持久化到磁盘(innodb_flush_log_at_trx_commit = 1 的作用);

- **commit 阶段**:把 XID 写入到 binlog,然后将 binlog 持久化到磁盘(sync_binlog = 1 的作用),接着调用引擎的提交事务接口,将 redo log 状态设置为 commit,此时该状态并不需要持久化到磁盘,只需要 write 到文件系统的 page cache 中就够了,因为只要 binlog 写磁盘成功,就算 redo log 的状态还是 prepare 也没有关系,一样会被认为事务已经执行成功;

这篇关于两阶段提交进阶的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1124744

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

作业提交过程之HDFSMapReduce

作业提交全过程详解 (1)作业提交 第1步:Client调用job.waitForCompletion方法,向整个集群提交MapReduce作业。 第2步:Client向RM申请一个作业id。 第3步:RM给Client返回该job资源的提交路径和作业id。 第4步:Client提交jar包、切片信息和配置文件到指定的资源提交路径。 第5步:Client提交完资源后,向RM申请运行MrAp

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

[MySQL表的增删改查-进阶]

🌈个人主页:努力学编程’ ⛅个人推荐: c语言从初阶到进阶 JavaEE详解 数据结构 ⚡学好数据结构,刷题刻不容缓:点击一起刷题 🌙心灵鸡汤:总有人要赢,为什么不能是我呢 💻💻💻数据库约束 🔭🔭🔭约束类型 not null: 指示某列不能存储 NULL 值unique: 保证某列的每行必须有唯一的值default: 规定没有给列赋值时的默认值.primary key:

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。

从0到1,AI我来了- (7)AI应用-ComfyUI-II(进阶)

上篇comfyUI 入门 ,了解了TA是个啥,这篇,我们通过ComfyUI 及其相关Lora 模型,生成一些更惊艳的图片。这篇主要了解这些内容:         1、哪里获取模型?         2、实践如何画一个美女?         3、附录:               1)相关SD(稳定扩散模型的组成部分)               2)模型放置目录(重要)

HTML提交表单给python

python 代码 from flask import Flask, request, render_template, redirect, url_forapp = Flask(__name__)@app.route('/')def form():# 渲染表单页面return render_template('./index.html')@app.route('/submit_form',

Python3 BeautifulSoup爬虫 POJ自动提交

POJ 提交代码采用Base64加密方式 import http.cookiejarimport loggingimport urllib.parseimport urllib.requestimport base64from bs4 import BeautifulSoupfrom submitcode import SubmitCodeclass SubmitPoj():de

java学习,进阶,提升

http://how2j.cn/k/hutool/hutool-brief/1930.html?p=73689