二阶段提交的 prepare 阶段,binlog 和 InnoDB 各自会有哪些动作?
本文基于 MySQL 8.0.32 源码,存储引擎为 InnoDB。
1. 二阶段提交
二阶段提交,顾名思义,包含两个阶段,它们是:
- prepare 阶段。
- commit 阶段。
我们只考虑 SQL 语句操作 InnoDB 表的场景,对于用户事务,是否使用二阶段提交,取决于是否开启了 binlog。
因为 MySQL 把 binlog 也看作一个存储引擎,开启 binlog,SQL 语句改变(插入、更新、删除)InnoDB 表的数据,这个 SQL 语句执行过程中,就涉及到两个存储引擎。
使用二阶段提交,就是为了保证两个存储引擎的数据一致性。
用户事务提交分为两种场景,如果开启了 binlog,它们都会使用二阶段提交。
场景 1:通过 BEGIN 或其它开始事务的语句,显式开始一个事务,用户手动执行 COMMIT 语句提交事务。
场景 2:没有显式开始的事务,一条 SQL 语句执行时,InnoDB 会隐式开始一个事务,SQL 语句执行完成之后,自动提交事务。
如果没有开启 binlog&