美文网首页
MySQL系列之四-InnoDB-02

MySQL系列之四-InnoDB-02

作者: 花神子 | 来源:发表于2020-02-10 13:02 被阅读0次

本文主要涉及两点:

  1. InnoDB 与 MyISAM 区别;
  2. InnoDB 架构分析;
  3. InnoDB 特性;

InnoDB架构

MySQL的架构

在具体说InnoDB架构之前,简单了解下MySQL的架构是怎么样的?


mysql-architect-Page

图是MySQL的基本架构图:(大体来说,MySQL可以分为Server层和存储引擎层两部分。)
架构示意图,可以理解出SQL语句在MySQL的各个功能模块中的执行过程。

  • Server层:
    包括连接器、查询缓存、分析器、优化器、执行器等,涵盖MySQL的大多数核心服务功能,以及所有的内置函数(如日期、时间、数学和加密函数等),所有跨存储引擎的功能都在这一层实现,比如存储过程、触发器、视图等(不同的存储引擎共用一个Server层)。

  • 存储引擎层:

  1. 负责数据的存储和提取。其架构模式是插件式的,支持InnoDB、MyISAM、Memory等多个存储引擎。现在最常用的存储引擎是InnoDB,它从MySQL 5.5.5版本开始成为了默认存储引擎。
  2. 执行create table建表的时候,如果不指定引擎类型,默认使用的就是InnoDB)。
  3. 在create table语句中使用engine=memory, 来指定使用内存引擎创建表。不同存储引擎的表数据存取方式不同,支持的功能也不同。
  4. MySQL服务内,可以以插件的形式,实现各种存储引擎。

InnoDB架构

在InnoDB,MyISAM,Memory…等各种存储引擎中,InnoDB是使用范围最广的事务,行锁,聚集索引,MVCC…

InnoDB-Structure
更为详细(图片来自官方网站的MySQL5.7的文档):
InnoDB-Structure

InnoDB整体也分为三层

  1. 内存结构(In-Memory Structure),这一层在MySQL服务进程内;
  2. OS Cache,这一层属于内核态内存;
  3. 磁盘结构(On-Disk Structure),这一层在文件系统上;
    三层之间的交互
  4. 通过OS Cache落地数据(短箭头)
  5. 直接O_Direct落地数据(长箭头)

InnoDB内存结构的核心组件

(1)缓冲池(Buffer Pool);
(2)写缓冲(Change Buffer);
(3)自适应哈希索引(Adaptive Hash Index);
(4)日志缓冲(Log Buffer);

详见:下小节MySQL-InnerDB特性

相关文章

网友评论

      本文标题:MySQL系列之四-InnoDB-02

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