• 【Mysql】 InnoDB引擎深入- InnoDB后台线程


    下图是简单的一个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 线程的压力。

  • 相关阅读:
    【ROS】机械人开发二--ROS环境安装
    ChatTuGraph:通过大模型“与图对话”
    JSP总结
    MySql第三篇---索引的创建与设计原则
    Spring boot 随笔 1 DatasourceInitializer
    vue如何解决闪光白屏问题
    原来我真的不懂Spring
    Linux基础开发工具之软件包管理器
    Java基础-----String类
    直播CDN调度技术关键挑战与架构设计
  • 原文地址:https://blog.csdn.net/qq_31142237/article/details/125448556