一、逻辑存储结构
mysql5.5版本开始,默认使用innodb存储引擎,它擅长事务处理,具有崩溃恢复特性,在日常开发中使用非常广泛。
架构图(左侧为内存架构,右侧为磁盘架构)
二、 内存架构。
1、缓冲池
2、更改缓冲区(针对于非唯一二级索引页)
3、自适应hash索引
开启状态
4、日志缓冲区
查看缓冲区大小,默认大小
日志刷新到磁盘时机,默认
三、磁盘架构。
1、系统表空间
参数:存放的就是系统表空间
2、独立表空间
默认开启:每一张表都会生成一个对应的表空间文件
3、通用表空间。
创建表空间
4、撤销表空间
5、临时表空间
6、双写缓冲区和重做日志
四、后台线程。
后台线程
1、master thread
核心后台线程,负责调度其他线程,还负责将缓冲池中的数据异步刷新到磁盘中,保持数据的一致性,还包括脏页的刷新,合并插入缓存、undo页的回收。
2、io thread
在innodb存储引擎中大量使用了aio来处理io请求,这样可以极大地提高数据库的性能,而io thread主要负责这些io请求的回调。
线程类型 | 默认个数 | 职责 |
---|---|---|
read thread | 4 | 负责读操作 |
write thread | 4 | 负责写操作 |
log thread | 1 | 负责将日志缓冲区刷新到磁盘 |
insert buffer thread | 1 | 负责将写缓冲区内容刷新到磁盘 |
查看innodb引擎状态信息:show engine innodb status。
3、purge thread
主要用于回收事务已经提交了的undo log,在事务提交之后,undo log可能不用了,就用它来回收。
4、page cleaner thread
协助master thread刷新脏页到磁盘的线程,它可以减轻master thread的工作压力,减少阻塞。