InnoDB的一次更新事务是怎么实现的?

2023年 10月 24日 62.0k 0

InnoDB的一次更新事务涉及到多个组件和步骤,包括Buffer Pool、BinLog、UndoLog、RedoLog以及物理磁盘。

图片[1]-InnoDB的一次更新事务是怎么实现的?-不念博客

下面是一次完整的事务更新操作过程:

1. 加载数据到缓存中(Buffer Pool):

在进行数据更新时,InnoDB首先会在缓冲池(Buffer Pool)中查找该记录是否已经在内存中。如果记录不在内存中,会将需要更新的数据从磁盘文件加载到内存的缓冲池(Buffer Pool)中。

缓冲池是InnoDB存储引擎提供的缓存,用于加速数据的读取和修改操作。数据加载到缓冲池后,后续的操作都在缓冲池中进行。

2. 写入Undo Log:

在更新数据之前,InnoDB会将原始数据的副本写入Undo Log(回滚日志)。

Undo Log是用于事务回滚和并发控制的重要组件,是用来保证事务原子性和一致性的一种机制。它记录了事务开始前的数据状态,以便在需要回滚时进行恢复。

3. 更新内存数据:

接下来,InnoDB会在缓冲池中更新数据。

这意味着,当执行update语句时,InnoDB会先更新已经读取到Buffer Pool中的数据,修改操作会直接在内存中进行,而不是立即写入磁盘。

此时,缓冲池中的数据被标记为”脏页”,表示与磁盘上的数据不一致。

4. 写入Redo Log:

为了保证事务的持久性,InnoDB在Buffer Pool中记录修改操作的同时,InnoDB会先将更新操作写入Redo Log(重做日志)。

Redo Log是一种物理日志,记录了事务对数据库的修改操作。

通过Redo Log,即使系统发生故障,也可以通过重做日志来恢复事务修改后的状态。

5. 提交事务:

当事务完成所有的更新操作后,事务被提交。

在提交事务时,InnoDB会将事务标记为”准备提交”状态。

此时,事务的修改操作仍然在缓冲池中,尚未写入磁盘。

6. 写入BinLog:

在事务提交之后,InnoDB会将事务的修改操作写入BinLog(归档日志)。

BinLog是MySQL的二进制日志,用于记录数据库的所有修改操作。

在Binlog中记录的信息包括:事务开始的时间、数据库名、表名、事务ID、SQL语句等。

它可以用于数据恢复、主从复制、数据分析和同步等场景。

7. 刷新脏页到磁盘:

最后,在提交过程完成后,InnoDB会将缓冲池(Buffer Pool)中的脏页刷新到物理磁盘上的数据文件中。

这个过程称为”刷脏”。通过刷脏操作,将缓冲池中的修改操作同步到磁盘,确保数据的持久性。

然而,这个写入过程并非立即执行,而是由后台线程异步执行的,因此可能会有一定的延迟。

总而言之,MySQL会在适当的时机选择将数据写入磁盘以进行持久化。

综上所述,InnoDB的一次更新事务涉及到多个组件和步骤,包括加载数据到缓存中、写入Undo Log、更新内存数据、写入Redo Log、提交事务、写入BinLog以及刷新脏页到磁盘。

这些步骤保证了事务的原子性、一致性、隔离性和持久性,确保数据库操作的正确执行和数据的完整性。

相关文章

Oracle如何使用授予和撤销权限的语法和示例
Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
社区版oceanbase安装
Oracle 导出CSV工具-sqluldr2
ETL数据集成丨快速将MySQL数据迁移至Doris数据库

发布评论