美文网首页
mysql两阶段提交

mysql两阶段提交

作者: Jaypc | 来源:发表于2020-11-03 18:43 被阅读0次

1.两阶段提交

MySQL中经常说的WAL技术,WAL的全称是Write- Ahead Logging,它的关键点就是先写日志,再写磁盘。即当有一条记录需要更新时,InnoDB引擎就会先把记录写到redo log里,并更新内存,这个时候更新就完成了。因为如果每一次的更新操作都需要写进磁盘,然后磁盘也要找到对应的那条记录,然后再更新,整个过程IO成本、查找成本都很高。


image.png

在执行一条update语句时候,通过连接器、分析器、优化器之后,调用操作引擎,将新行写入内存,写入redo log,状态为prepare->写binlog->redo log状态修改为commit。写入redo的过程分为了prepare和commit称为二阶段提交。
采用二阶段提交的原因
如果只进行一次写入redolog和写入binlog是有问题的。不管先写谁。首先知道一点,redolog是对数据库实际进行的操作。

redo和binlog这两种日志有以下三点不同:
1、 redo log 是 InnoDB 引擎特有的;binlog 是 MySQL 的 Server 层实现的,所有引擎都可以使用。
2、 redo log 是物理日志,记录的是“在某个数据页上做了什么修改”;binlog 是逻辑日志,记录的是这个语句的原始逻辑,比如“给 ID=2 这一行的 c 字段加 1 ”。
3、redo log 是循环写的,空间固定会用完;binlog 是可以追加写入的。“追加写”是指 binlog 文件写到一定大小后会切换到下一个,并不会覆盖以前的日志。

2.采用二阶段提交的原因

先写redolog再写binlog
如果在一条语句redolog之后崩溃了,binlog则没有记录这条语句。系统在crash recovery时重新执行了一遍binlog便会少了这一次的修改。恢复的数据库少了这条更新。
先写binlog再写redolog
如果在一条语句binlog之后崩溃了,redolog则没有记录这条语句(数据库物理层面并没有执行这条语句)。系统在crash recovery时重新执行了一遍binlog便会多了这一次的修改。恢复的数据库便多了这条更新。

Crash recovery

在做Crash recovery时,分为以下3种情况:
binlog有记录,redolog状态commit:正常完成的事务,不需要恢复;
binlog有记录,redolog状态prepare:在binlog写完提交事务之前的crash,恢复操作:提交事务。(因为之前没有提交)
binlog无记录,redolog状态prepare:在binlog写完之前的crash,恢复操作:回滚事务(因为crash时并没有成功写入数据库)

相关文章

  • MySQL更新流程——两阶段提交

    两阶段提交的目的是什么 MySQL使用两阶段提交主要解决 binlog 和 InnoDB redo log 的数据...

  • mysql两阶段提交

    1.两阶段提交 MySQL中经常说的WAL技术,WAL的全称是Write- Ahead Logging,它的关键点...

  • MySQL两阶段提交串讲

    目录: 一、吹个牛 二、事务及它的特性 三、简单看下两阶段提交的流程 四、两阶段写日志用意? 五、加餐:sync_...

  • 第二十一节、问题答疑

    1、在两阶段提交的不同瞬间,MySQL如果发生异常重启,是专门保证数据完整性的? 在两阶段提交的不同时刻,MySQ...

  • 【MySQL】15|日志和索引相关问题

    1 在两阶段提交的不同瞬间,MySQL如果发生异常重启,是怎么保证数据完整性的? 我们先来看下,两阶段提交的图 如...

  • mysql

    浅谈mysql的两阶段提交协议https://www.cnblogs.com/hustcat/p/3577584....

  • 分布式事务

    XA分布式事务协议 - 两阶段提交 & 三阶段提交 两阶段提交 两阶段提交存在的缺点 三阶段提交

  • 两阶段提交

    一、两阶段事务提交模型 二、实现方案1、数据库层实现 缺点:锁持有时间长、单点、阻塞等 2、业务层面实现 1、tc...

  • 15 | 答疑(一):日志和索引相关问题

    日志相关问题 两阶段提交不同瞬间,MySQL异常重启,怎么保证数据完整? 不是update 语句执行流程吗,怎么调...

  • 分布式事务

    对分布式事务及两阶段提交、三阶段提交的理解 关于分布式事务、两阶段提交协议、三阶提交协议

网友评论

      本文标题:mysql两阶段提交

      本文链接:https://www.haomeiwen.com/subject/xfubvktx.html