当前位置: 首页 > article >正文

redo log 和 bin log 的两阶段提交

两阶段提交的过程

当事务提交后,有一个两阶段提交策略。

在开启两阶段提交时,会开启一个 XA 事务(宏观上的事务),

Prepare 阶段:将 redo log 的状态设置为 prepare,然后将 事务XID 写入 redo log,然后提交 redo log

Commit 阶段:将事务 XID 写入bin log,然后对 bin log 刷盘,最后将 redo log 的状态设置为 commit

当断电后,进行崩溃恢复时,会按照顺序扫描 redo log 文件

  1. 会首先查看 redo log 的状态,如果 redo log 的状态为 commit,则说明事务的两阶段提交已经完成,可以放心进行数据恢复。

  2. 如果 redo log 状态为 prepare,则检查 redo log 中的 XID

  3. 再根据 XID 去 bin log 中进行查找,如果 bin log 中不存在 XID,则说明 虽然 redo log 刷盘了,但是 bin log 没有刷盘,此时会进行事务回滚(根据 undo log 回滚)

  4. 如果 bin log 存在 XID,则虽然 redo log 处于 prepare 状态,但 bin log 已经刷盘了,此时会对事务进行提交。同时也可以放心进行数据恢复。

为什么有两阶段提交

主要是为了保证主从数据库一致性。

若没有两阶段提交,可能发生 redo log 已经刷入磁盘但 bin log 没有刷入磁盘,或者 bin log 已经刷入磁盘而 redo log 没有刷入磁盘的情况。如果是前者,若断电,则崩溃恢复后主数据库的数据可以恢复,而从数据库从 bin log 中获取到的数据是有缺失的,从而导致主从不一致。如果是后者,若断电,则恢复后,主数据库的数据会丢失,而从数据库的数据可以恢复完整,也会导致主从不一致现象。


http://www.kler.cn/news/335368.html

相关文章:

  • 【MySQL】MySQL 数据库主从复制详解
  • Qt QWidget控件
  • Spring Boot项目使用MyBatis Plus的详细步骤
  • Apache POI 2024/10/2
  • 【TypeScript学习】TypeScript基础学习总结一
  • 计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-05
  • 在 Ubuntu 18.04 上安装 Syncthing
  • Mac通过ssh连接工具远程登录服务器( Royal TSX安装及使用)
  • sql-labs靶场第九关测试报告
  • GiliSoft Video Editor Pro专业视频编辑工具-视频剪辑/合并/字幕于一身的编辑器-供大家学习研究参考
  • 硬件面试(一)
  • JavaScript for循环语句
  • Spring Boot 2.1.6.RELEASE 中,javax.persistence缺失问题
  • Star 3w+,向更安全、更泛化、更云原生的 Nacos3.0 演进
  • Python 时间日期模块编码模板(时间日期对象基本操作、时间日期对象格式化与解析)
  • Java语法-类和对象之抽象类和接口
  • node启动websocket保持后台一直运行
  • Linux命令:用于管理 Linux 系统中用户组的命令行工具gpasswd详解
  • 【深度学习】—线性回归 线性回归的基本元素 线性模型 损失函数 解析解 随机梯度下降
  • kaggle实战3RossmanStore商店销售额预测XgBoost解决回归问题案例1