MySQL--InnoDB存储引擎--架构

目录

一、InnoDB存储引擎的架构

二、InnoDB架构设计的原因


一、InnoDB存储引擎的架构

下图是官方给出的架构图,可以看出InnoDB主要包括内存结构和磁盘结构:

内存结构包括:缓冲池(Buffer Pool)、变更缓冲区(Change Buffer) 、日志缓冲区(Log Buffer)、自适应哈希(Adaptive Hash Index)

磁盘结构包括:系统表空间(System Tablespace)、独立表空间(File-Per-Table Tablespaces)、通用表空间(General Tablespaces)、临时表空间(Temporary Tablespaces)、撤销表空间(Undo Tablespaces)、重做日志(Redo Log)、双写缓冲区(Doublewrite Buffer)

二、InnoDB架构设计的原因

我们知道数据库的作用就是用于保存数据,用户的真实数据最终都会保存在磁盘上,在查询数据的过程中,如果每次都需要从磁盘上读取就会相当的影响效率,为了提高数据的访问效率,InnoDB就会将查询到的数据缓存到内存上,当再次查询时,如果目标数据已经缓存在内存上就可以直接从内存上读取数据,从而大幅提升效率。

综上所述,也就是说磁盘结构中的文件是用来保存数据实现数据的持久化的,内存结构是用于缓存数据提高效率的。

相关推荐
恋红尘16 分钟前
Mysql
数据库·mysql
paishishaba27 分钟前
数据库设计原则
数据库
曹牧1 小时前
oracle:NOT IN
数据库·oracle
爬山算法2 小时前
Redis(66)Redis如何实现分布式锁?
数据库·redis·分布式
Super Rookie2 小时前
MongoDB 自动化脚本安装方案
数据库·mongodb·自动化
Code哈哈笑2 小时前
【MongoDB 基本语法】数据库和集合的基本操作--探秘 MongoDB
数据库·mongodb
恋红尘3 小时前
Redis面试八股
数据库·redis·面试
直有两条腿4 小时前
【数据迁移】HBase Bulkload批量加载原理
大数据·数据库·hbase
言之。4 小时前
ClickHouse 数据更新策略深度解析:突变操作与最佳实践
服务器·数据库·clickhouse
m0_64880493_江哥4 小时前
用正则方法从中英文本提取英文的python示例
python·mysql·正则表达式