InnoDB存储引擎

体系架构

InnoDB存储引擎体系架构如下图:
这里写图片描述

从图可见,InnoDB存储引擎有多个内存块,可以认为这些内存块组成了一个大的内存池,负责如下工作:

  • 维护所有进程/线程需要访问的多个内部数据结构
  • 缓存磁盘上的数据,方便快速地读取,同时在对磁盘文件的数据修改之前在这里缓存。
  • 重做日志(redo log)缓存
  • ……

后台线程的主要作用是负责刷新内存中的数据,保证缓冲池中的内存缓存的是最近的数据。此外将已修改的数据文件刷新到磁盘文件,同时保证在数据库发生异常的情况下InnoDB能恢复到正常运行状态。

后台线程

InnoDB存储引擎是多线程模型,后台有多个不同的后台线程,负责处理不同的任务。

Master Thread

非常核心的后台线程
将缓冲池中的数据异步刷新到磁盘,保证数据的一致性,包括脏页的刷新、合并插入缓冲(insert buffer)、UNDO页的回收等

IO Thread

在InnoDB存储引擎中大量使用了AIO来处理写IO请求,这样可以极大提高数据库的性能。IO Thread的工作主要是负责这些I/O请求的回调处理。
通过命令show engine innodb status来观察InnoDB的IO Thread。

show engine innodb status;

FILE I/O——–
I/O thread 0 state: wait Windows aio (insert buffer thread)
I/O thread 1 state: wait Windows aio (log thread)
I/O thread 2 state: wait Windows aio (read thread)
I/O thread 3 state: wait Windows aio (read thread)
I/O thread 4 state: wait Windows aio (read thread)
I/O thread 5 state: wait Windows aio (read thread)
I/O thread 6 state: wait Windows aio (write thread)
I/O thread 7 state: wait Windows aio (write thread)
I/O thread 8 state: wait Windows aio (write thread)
I/O thread 9 state: wait Windows aio (write thread)
……

可见有4个读线程和4个写线程,并且读线程的ID总是小于写线程

Purge Thread

事务被提交后,其所使用的undo log可能不再需要,因此需要Purge Thread来回收使用并分配的undo页。

InnoDB1.1之前,purge操作仅在InnoDB存储引擎的Master Thread中完成。
InnoDB1.1开始,purge操作可以独立到单独的线程中进行 单线程
innodb_purge_threads = 1
InnoDB1.2开始,InnoDB支持多个Purge Thread。多线程
这样做的目的是为了进一步加快undo页的回收。同时由于Purge Thread需要离散地读取undo页,这样也能更进一步利用磁盘的随机读取性能。

Page Cleaner Thread

InnoDB 1.2.x版本中引入的。将之前版本中脏页的刷新操作都放入到单独的线程中完成。其目的是减轻原Master Thread的工作及对于用户查询线程的阻塞,进一步提高InnoDB存储引擎的性能。

内存
缓冲池

InnoDB存储引擎是基于磁盘存储的,并将其中的记录按照页的方式进行管理。
由于CPU速度和磁盘速度之间的鸿沟,基于磁盘的数据库系统通常使用缓冲池技术来提高数据库的整体性能。

在数据库中进行读取页的操作,首先将从磁盘读到的页存放在缓冲池中,这个过程称为将页“FIX”在缓冲池中。下一次在读相同的页时,首先判断该页是否在缓冲池中。若在,称该页在缓冲池中被命中,直接读取该页。否则,读取磁盘上的页。

对于数据库中页的修改操作,则首先修改在缓冲池中的页,然后再以一定的频率刷新到磁盘上。注意:页从缓冲池刷新回磁盘的操作并不是在每次页发生更新时触发,而是通过一种Checkpoint机制刷新回磁盘。

缓冲池配置
参数:innodb_buffer_pool_size

缓冲池中缓存的数据页类型:索引页、数据页(前面两个占很大一部分)、undo页、插入缓冲(insert buffer)、自适应哈希索引(adaptive hash index)、InnoDB存储的锁信息(lock info)、数据字典信息(data dictionary)等
InnoDB内存数据对象

这里写图片描述

从InnoDB 1.0.x版本开始,允许有多个缓冲池实例。每个页根据哈希值平均分配到不同缓冲池实例中。这样做的好处是减少数据库内部的资源竞争,增加数据库的并发处理能力。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值