【MySQL-二阶段提交】

MySQL 的二阶段提交主要基于日志(redo log 和 binlog)来实现。

一、redo log(重做日志)

  1. 作用:

    • redo log 是 InnoDB 存储引擎特有的日志,用于记录对数据页的物理修改。
    • 它的目的是在数据库发生故障时,能够恢复未写入磁盘的数据,保证事务的持久性。
  2. 与二阶段提交的关系:

    • 在事务执行过程中,InnoDB 引擎会先将修改操作记录到 redo log 中,但是此时并不立即写入磁盘,而是在事务提交时进行持久化。
    • 在二阶段提交的准备阶段,InnoDB 会将 redo log 刷新到磁盘,并将事务状态设置为“准备提交”。在提交阶段,再次刷新 redo log,确保事务的修改被永久保存。

二、binlog(二进制日志)

  1. 作用:

    • binlog 是 MySQL 服务器级别的日志,记录了所有对数据库的修改操作,包括数据的插入、更新和删除等。
    • 它主要用于数据备份、主从复制等场景。
  2. 与二阶段提交的关系:

    • 在二阶段提交的准备阶段,MySQL 服务器不会将事务的修改写入 binlog。只有在提交阶段,才会将事务的修改写入 binlog。
    • 这样可以保证 redo log 和 binlog 的一致性,即如果事务在 redo log 中被标记为已提交,那么它在 binlog 中也一定是已提交的状态。

三、协调者(事务管理器)

  1. 作用:

    • 在 MySQL 中,事务管理器负责协调二阶段提交的过程。
    • 它会向涉及的存储引擎(如 InnoDB)发送准备和提交请求,并根据存储引擎的回复决定下一步的操作。
  2. 实现方式:

    • 事务管理器通过读取和写入事务相关的系统表和状态变量来跟踪事务的状态。
    • 在二阶段提交的过程中,事务管理器会根据 redo log 和 binlog 的状态来判断事务是否可以提交或回滚。

总之,MySQL 的二阶段提交是通过 redo log 和 binlog 以及事务管理器的协调来实现的。这种机制保证了事务的原子性和持久性,同时也为数据备份、主从复制等功能提供了基础。

  • 9
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

越来越亮

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值