本文主要涉及两点:
- InnoDB 与 MyISAM 区别;
- InnoDB 架构分析;
- InnoDB 特性;
InnoDB架构
MySQL的架构
在具体说InnoDB架构之前,简单了解下MySQL的架构是怎么样的?
图是MySQL的基本架构图:(大体来说,MySQL可以分为Server层和存储引擎层两部分。)
架构示意图,可以理解出SQL语句在MySQL的各个功能??橹械闹葱泄?。
Server层:
包括连接器、查询缓存、分析器、优化器、执行器等,涵盖MySQL的大多数核心服务功能,以及所有的内置函数(如日期、时间、数学和加密函数等),所有跨存储引擎的功能都在这一层实现,比如存储过程、触发器、视图等(不同的存储引擎共用一个Server层)。存储引擎层:
- 负责数据的存储和提取。其架构模式是插件式的,支持InnoDB、MyISAM、Memory等多个存储引擎。现在最常用的存储引擎是InnoDB,它从MySQL 5.5.5版本开始成为了默认存储引擎。
- 执行create table建表的时候,如果不指定引擎类型,默认使用的就是InnoDB)。
- 在create table语句中使用engine=memory, 来指定使用内存引擎创建表。不同存储引擎的表数据存取方式不同,支持的功能也不同。
- MySQL服务内,可以以插件的形式,实现各种存储引擎。
InnoDB架构
在InnoDB,MyISAM,Memory…等各种存储引擎中,InnoDB是使用范围最广的,事务,行锁,聚集索引,MVCC…
更为详细(图片来自官方网站的MySQL5.7的文档):
InnoDB整体也分为三层
- 内存结构(In-Memory Structure),这一层在MySQL服务进程内;
- OS Cache,这一层属于内核态内存;
-
磁盘结构(On-Disk Structure),这一层在文件系统上;
三层之间的交互 - 通过OS Cache落地数据(短箭头)
- 直接O_Direct落地数据(长箭头)
InnoDB内存结构的核心组件
(1)缓冲池(Buffer Pool);
(2)写缓冲(Change Buffer);
(3)自适应哈希索引(Adaptive Hash Index);
(4)日志缓冲(Log Buffer);
详见:下小节MySQL-InnerDB特性