石家庄网站外包开发公司招标流程及管理制度
一、逻辑存储结构

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的工作压力,减少阻塞。
