Mysql - InnoDB架构

背景

mysql 版本: mysql8.0
参考资料: mysql官网

一、InnoDb官方架构图

image.png

二、简要说明

InnoDb架构划分为内存结构磁盘结构

1. 内存结构

1.1 buffer pool(缓冲池)

buffer pool是主存中的一个区域,InnoDB在访问表和索引数据时在这里进行缓存。buffer pool允许直接从内存访问常用数据,从而提高处理速度。在专用服务器上,多达80%的物理内存通常分配给缓冲池。

更多关于buffer pool的信息可以参考 - Mysql - InnoDB - 理解buffer pool

1.2 change buffer(变更缓冲)

change buffer是一种特殊的数据结构,当二级索引页不在buffer poole中时,它将更改缓存到二级索引页。缓冲的更改(可能由INSERTUPDATEDELETE操作(DML)引起)稍后在其他读操作将页面加载到缓冲池时合并。

更多关于buffer pool的信息可以参考 - Mysql - InnoDB - 理解change buffer

1.3 adaptive hash index(自适应哈希索引)

自适应哈希索引使InnoDB能够在具有适当的工作负载组合缓冲池足够内存的系统上执行,更像内存中的数据库,而不会牺牲事务特性或可靠性。自适应哈希索引通过innodb_adaptive_hash_index变量启用,或者在服务器启动时通过——skip-innodb- adaptive_hash -index关闭。

详细介绍地址: 待续......

1.4 log buffer(日志缓冲)

log buffer区是存储要写入磁盘日志文件的数据的内存区域。log buffer大小由innodb_log_buffer_size变量定义。默认的大小是16MB。定期将log buffer的内容刷新到磁盘。大log buffer使大事务能够运行,而无需在事务提交之前将redo log数据写入磁盘。因此,如果您有更新、插入或删除许多行的事务,那么增加log buffer的大小可以节省磁盘I/O。

详细介绍地址: 待续......

2. 磁盘结构

2.1 tables

详细介绍地址: 待续......

2.2 indexes

详细介绍地址: 待续......

2.3 tablespace(表空间)

表空间包含了系统表空间独立表空间通用表空间临时表空间以及undo表空间

2.3.1 系统表空间:

a、系统表空间主要是change buffer的存储区域;

b、如果表是在系统表空间中创建的而不是在独立表空间或者通用表空间中创建的,那么系统表空间中也存储创建的表和索引数据;

c、在mysql8.0版本之前,mysql数据字典也存储在系统表空间之中,不过8.0版本之后,mysql合并了一个事务性数据字典,元数据存储在数据字典中;

d、在MySQL 8.0.20之前,double write buffer存储区域位于InnoDB系统表空间中。从MySQL 8.0.20开始,double write buffer存储区域位于double write文件中;

详细介绍地址: 待续......

2.3.2 独立表空间

独立表空间中包含了innoDb表的数据和索引信息,存放在单个的独立表空间文件

详细介绍地址: 待续......

2.3.3 通用表空间

通用表空间是指使用CREATE tablespace语法创建的共享InnoDB表空间

详细介绍地址: 待续......

2.3.4 临时表空间

innoDb中使用临时表空间分为session临时表空间global临时表空间

详细介绍地址: 待续......

2.3.5 undo表空间

Undo表空间包含Undo logUndo log是记录的集合,这些记录包含关于如何撤销事务对聚集索引记录的最新更改的信息。

详细介绍地址: 待续......

2.4 double write buffer

double write buffer是一个存储区域,InnoDB在将页面写到InnoDB数据文件中的适当位置之前,在这个存储区域中写入从buffer pool中刷新的页面。如果在页写过程中出现了操作系统、存储子系统或意外的mysqld进程退出,InnoDB可以在崩溃恢复期间从double write buffer中找到一个好的页副本。

虽然数据被写入两次,但double write buffer并不需要两倍的I/O开销或两倍的I/O操作。数据在一个大的顺序块中写入doublewrite缓冲区,通过对操作系统的单个fsync()调用(除非innodb_flush_method设置为O_DIRECT_NO_FSYNC)。

MySQL 8.0.20之前,double write buffer存储区域位于InnoDB系统表空间中。从MySQL 8.0.20开始,double write buffer存储区域位于double write文件中。

详细介绍地址: 待续......

2.5 redo log(重做日志)

redo log是一种基于磁盘的数据结构,在崩溃恢复期间用于纠正不完整事务写入的数据。在正常操作过程中,redo log对SQL语句或低级API调用产生的表数据更改请求进行编码。在意外关闭之前未完成数据文件更新的修改将在初始化期间和接受连接之前自动重播。关于redo log在崩溃恢复中的作用,请参见15.18.2节“InnoDB恢复”

默认情况下,redo log在物理上由两个名为ib_logfile0ib_logfile1的文件表示。MySQL以循环的方式写入redo log文件。redo log中的数据按照受影响的记录进行编码;这些数据统称为重做。数据通过redo log的通道由不断增加的LSN值表示。

详细介绍地址: 待续......

2.6 undo logs

undo log是与单个读写事务相关联的undo log记录的集合。undo记录包含关于如何撤销事务对聚集索引记录的最新更改的信息。

详细介绍地址: 待续......

未完待续......

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351

推荐阅读更多精彩内容