Innodb Buffer Pool缓存机制(一)一条sql的执行过程

思维导图

石墨文档:https://shimo.im/mindmaps/NJkbnZV0ePINXzkR

一、SQL的执行

执行过程:

  1. 加载缓存数据,加载id为1的记录所在的整页数据(相当于索引树的一个结点,16KB);
  2. 写入更新数据的旧值到undo日志中,方便回滚;
  3. 执行器更新BufferPool缓存池中的内存数据;
  4. 写入redo日志,将操作结果写入Redo Log Buffer缓冲区;
  5. 准备提交事务,redo日志写入磁盘中;
  6. 准备提交事务,将结果写入binlog日志,binlog日志写入磁盘,binlog主要用来恢复数据库磁盘里的数据;
  7. 写入commit标记到redo日志文件里,提交事务完成,该标记为了保证事务提交后的redo与binlog数据一致;
  8. 将Buffer Pool缓冲池中修改后的数据随机写入磁盘,以Page为单位写入,执行完后,磁盘中的name=zhuge666;

1.1 redo日志作用

如果事务提交成功,buffer pool里的数据还没吸入磁盘,此时系统宕机,可以用redo日志里的数据恢复buffer pool里的缓存数据,再重新写入磁盘;

1.2 undo日志作用

当事务更新完数据后,执行其它操作发生错误,导致事务执行失败,MySQL会将undo日志里最新的旧值回滚,保证数据一致性;

undo日志更详细介绍的介绍在:1.3 MVCC

1.3 MVCC

参考这篇文章:MVCC是什么?有何用?原理是什么?

1.4 为什么Mysql不能直接更新磁盘上的数据而且设置这么一套复杂的机制来执行SQL了?

因为来一个请求就直接对磁盘文件进行随机读写,然后更新磁盘文件里的数据性能相当查;

因为磁盘随机读写的性能是相当差的,所以直接更新磁盘文件是不能让数据库抗住高并发请求的。

MySQL这套机制看起来复杂,但他保证每个请求都是更新内存(BufferPool),然后顺序写日志文件,同时还能保证各种异常情况下的数据一致性;

更新内存的性能 和顺序写磁盘上的日志文件的性能远比更新磁盘的性能高的多。

相关推荐
wrx繁星点点8 分钟前
事务的四大特性(ACID)
java·开发语言·数据库
小小娥子37 分钟前
Redis的基础认识与在ubuntu上的安装教程
java·数据库·redis·缓存
DieSnowK39 分钟前
[Redis][集群][下]详细讲解
数据库·redis·分布式·缓存·集群·高可用·新手向
-XWB-1 小时前
【MySQL】数据目录迁移
数据库·mysql
老华带你飞1 小时前
公寓管理系统|SprinBoot+vue夕阳红公寓管理系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·spring boot·课程设计
我明天再来学Web渗透2 小时前
【hot100-java】【二叉树的层序遍历】
java·开发语言·数据库·sql·算法·排序算法
Data 3172 小时前
Hive数仓操作(十一)
大数据·数据库·数据仓库·hive·hadoop
吱吱鼠叔2 小时前
MATLAB数据文件读写:2.矩阵数据读取
数据库·matlab·矩阵
掘根2 小时前
【MySQL】Ubuntu环境下MySQL的安装与卸载
数据库·mysql·centos