MySQL 学习总结 之 初步了解 InnoDB 存储引擎的架构设计

 更新时间:2020年02月10日 09:49:08   作者:不送花的程序猿  
这篇文章主要介绍了MySQL 学习总结 之 初步了解 InnoDB 存储引擎的架构设计,文中给大家提到了mysql存储引擎有哪些,本文给大家介绍的非常详细,需要的朋友可以参考下

一、存储引擎

上节我们最后说到,SQL 的执行计划是执行器组件调用存储引擎的接口来完成的。
那我们可以理解为:MySQL 这个数据库管理系统是依靠存储引擎与存放数据的磁盘文件进行交互的。

那么 MySQL 有哪些存储引擎呢?

主要有 MyISAM、InnoDB、Memory等等。而现在互联网中,基本都是使用 InnoDB 存储引擎,所以接下来我将简单总结自己关于 InnoDB 存储引擎的学习,比较简单的介绍 InnoDB 存储引擎里面的组件。

二、缓冲池

我们现在都知道了,数据库的数据是存放在磁盘文件中的。
那么,我们每次对表的增删改查都是直接在磁盘文件里面操作吗?

答案:不是的!

因为磁盘文件的随机读写的性能是非常差的,如果所有操作都在磁盘中进行,那么就不会有高性能 MySQL 的说法了,MySQL 也不能支持高并发,也不会在互联网中如此的流行。

这时候要引入 InnoDB 存储引擎最重要的一个组件,就是缓冲池(Buffer Pool),它是一个非常重要的内存结构。它是内存里面的,凭借着内存非常高性能的读写,使得 MySQL 能够支持高并发。

缓冲池(Buffer Pool) 的使用原理:

我们先复习一下 MySQL 接收请求的过程。

①、MySQL 的工作线程专门监听数据库连接池的连接,有连接就获取连接中的 SQL 语句。
②、然后将 SQL 语句交给 SQL 接口 去处理,SQL 接口里会进行下面的一系列流程。
③、查询解析器 将 SQL 语句解析成 MySQL 能理解的东西。
④、接着 查询优化器 去为 SQL 语句制定一套最优的执行计划。
⑤、执行器 会根据执行计划去调用存储引擎的接口。

上面是上篇文章总结到的东西,那么存储引擎的接口是怎么进行增删改查的呢?以更新操作为例,其他的同理。
首先,存储引擎会先判断更新 SQL 对应的数据行是否在 缓冲池(Buffer Pool) 里面。如果在的话就直接在 缓冲池(Buffer Pool) 里更新数据然后返回;如果不在,则从磁盘文件里读取数据到 缓冲池(Buffer Pool) 里,然后进行更新操作,最后再返回结果。

三、undo 日志文件

我们都知道,在事务中,事务提交前是可以随时回滚对数据的更新的。那么是依靠什么来做的呢?

依靠的是 undo 日志文件

undo 日志文件的使用原理:

更新数据为例:
假如你更新某行 id=100 的数据,将字段 name 由原来的“张三”改为“李四”,那么此时会将 "id=10" 和 “name=张三” 这两个关键信息写入 undo 日志文件中。
当你事务提交前需要回滚,就会从 undo 日志文件 中找到这两个关键字,然后进行更新操作的回滚。

四、redo log buffer

上面说到,所有的增删改查操作其实是在缓冲池里面进行的,所以其实对数据的修改并没有立刻落实到磁盘文件里面。

那么有一个问题:在缓冲池的脏数据刷回磁盘文件中前,MySQL 宕机了怎么办?
此时 InnoDB 存储引擎提供了一个非常重要的组件,就是 redo log buffer 组件.,它也是内存里的一块缓冲区。

redo log buffer 的使用原理:

还是以上面的更新操作为例,当数据更新后,会记录下数据更新的的关键信息,对应的就是 redo 日志,然后写入 redo log buffer 里。

但是还是会有一个问题,上面说到,redo log buffer 也是在内存里的。那当 MySQL 宕机时,由于内存里的所有数据都会丢失,所以缓冲池的脏数据和 redo log buffer 的日志还是会全部丢失。
这样会造成一种情况,客户端收到更新成功的信息了,但是最后数据库里头的数据还是没更新成功。

所以,redo log buffer 还有一个刷盘策略。正常是,当事务提交时,会将 redo log buffer 里的 redo 日志 刷回到磁盘中,这样就不用担心,事务提交成功,但是更新数据可能会丢失的问题了。即使在 缓冲池(Buffer Pool) 的脏数据刷回磁盘前, MySQL 宕机了,也不会丢失数据,因为 MySQL 重启时可以根据磁盘中的 redo 日志 恢复之前所有脏数据的更新。

总结

以上所述是小编给大家介绍的MySQL 学习总结 之 初步了解 InnoDB 存储引擎的架构设计,希望对大家有所帮助!

相关文章

  • MySQL性能分析及explain的使用说明

    MySQL性能分析及explain的使用说明

    本文我们主要介绍了MySQL性能分析以及explain的使用,包括:组合索引、慢查询分析、MYISAM和INNODB的锁定、MYSQL的事务配置项等,希望能够对您有所帮助。
    2011-08-08
  • select into from和insert into select的区别举例详解

    select into from和insert into select的区别举例详解

    这篇文章主要介绍了SQL中的SELECT INTO和INSERT INTO SELECT两种语句的区别和用法,SELECT INTO用于创建新表并复制数据到新表中,而INSERT INTO SELECT用于将数据从一个表插入到已存在的另一个表中,需要的朋友可以参考下
    2025-03-03
  • mysql中tonumber函数使用及注意事项

    mysql中tonumber函数使用及注意事项

    在MySQL中,没有直接的TO_NUMBER函数,但可以通过CAST或CONVERT实现字符串到数字的转换,转换前需明确数据类型,了解转换语法,并注意错误处理、空值处理、格式合规性和精度问题,本文介绍mysql中tonumber函数使用及注意事项,感兴趣的朋友一起看看吧
    2025-02-02
  • MySQL中的联合索引学习教程

    MySQL中的联合索引学习教程

    这篇文章主要介绍了MySQL中的联合索引学习教程,其中谈到了联合索引对排序的优化等知识点,需要的朋友可以参考下
    2015-11-11
  • 浅析一个MYSQL语法(在查询中使用count)的兼容性问题

    浅析一个MYSQL语法(在查询中使用count)的兼容性问题

    本篇文章是对MYSQL语法(在查询中使用count)的兼容性问题进行了详细的分析介绍,需要的朋友参考下
    2013-07-07
  • MySQL的mysqldump工具用法详解

    MySQL的mysqldump工具用法详解

    这篇文章主要介绍了MySQL的mysqldump工具用法详解,同时附带了相关Source命令的用法,详解需要的朋友可以参考下
    2015-07-07
  • mysql 中如何取得汉字字段的各汉字首字母

    mysql 中如何取得汉字字段的各汉字首字母

    这篇文章主要介绍了mysql中如何取得汉字字段的各汉字首字母,需要的朋友可以参考下
    2014-08-08
  • Mysql多层子查询示例代码(收藏夹案例)

    Mysql多层子查询示例代码(收藏夹案例)

    这篇文章主要介绍了Mysql多层子查询示例代码,以收藏夹案例给大家详细介绍,代码简单易懂,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • win10下完全卸载+重装MySQL步骤详解

    win10下完全卸载+重装MySQL步骤详解

    小编是因为连接MySQL和Qt时出现问题,迫不得已选择把64bitMySQL换成了32bitMySQL,在安装过程中出现各种问题,下面小编把 win10下完全卸载+重装MySQL步骤分享到脚本之家平台,需要的朋友参考下
    2017-12-12
  • 简单了解添加mysql索引的3条原则

    简单了解添加mysql索引的3条原则

    这篇文章主要介绍了简单了解添加mysql索引的3条原则,如果表中查询的列有一个索引,MySQL能快速到达一个位置去搜寻到数据文件的中间,没有必要看所有数据,需要的朋友可以参考下
    2019-06-06

最新评论