下图是简单的一个InnoDB体系架构图,InnoDB存储引擎有多个内存快组成的内存池,负责如下工作:
-
维护所有进程|线程需要访问的多个内部数据结构。
-
缓存磁盘上的数据,方便快速的读取,同时在对磁盘文件的数据进行修改之前在这里进行缓存。
-
重做日志
-
.....
后台线程的主要目的就是负责刷新内存池中的数据,保证缓冲池中的缓存数据时最近的数据。此外将已经修改的数据文件刷新到磁盘文件,同时保证在数据库发生异常情况下InnoDB能恢复到正常状态。
核心线程如下:
Master Thread:是一个非常核心的后端线程,主要负责将缓冲池中的数据异步刷新到磁盘中,保证数据一致性。包括脏页的刷新、insert buffer、undo页的回收等。
IO Thread: InnoDB引擎使用了大量的异步IO 来处理 写IO请求,这样可以极大的提高数据库的性能。而IO Thread线程主要就是这些IO请求的一个回调处理。
Purge Thread:当事务被提交之后,用于回收可能不再需要的undolog所使用的页。
Page Cleaner Thread:为了提高InnoDB引擎的性能,在1.2x版本引入该线程,主要用于将之前版本中脏页的刷新操作放入单独线程,目的为了减轻原Master Thread 线程的压力。