博客
关于我
Mysql数据库 InnoDB存储引擎中Master Thread的执行流程
阅读量:806 次
发布时间:2023-02-12

本文共 669 字,大约阅读时间需要 2 分钟。

InnoDB线程的工作机制主要由主循环、后台循环、清理循环和暂停循环四个部分组成。在InnoDB1.0.X版本之前,主循环的操作主要分为每秒和每十秒两部分。

每秒操作

每秒钟主循环会执行以下任务:

  • 刷新日志文件至磁盘。
  • 判断脏页占比,决定是否需要刷新(通常刷新100个脏页)。
  • 检查磁盘IO次数,判断是否需要合并插入缓冲(通常每秒一次,磁盘IO超过5次则合并)。
  • 如果没有用户事件,则切换至后台循环。
  • 每十秒操作

    每十秒主循环会执行以下任务:

  • 如果前十秒磁盘IO总次数未超过20次,则刷新100个脏页。
  • 清理Undo缓冲。
  • 合并5个插入缓冲。
  • 刷新日志缓冲至日志文件。
  • 刷新100个脏页或10个脏页(根据配置决定)。
  • 后台循环

    后台循环的主要任务是处理InnoDB存储引擎的事务。如果没有事务可处理,则切换至清理循环:

  • 清理Undo缓冲。
  • 合并20个插入缓冲。
  • 判断是否有事务可做,若无则进入清理循环。
  • 清理循环

    清理循环根据Buffer Pool中脏页比例判断是否需要刷新:

  • 如果脏页比例超过设定值,刷新100个脏页。
  • 当脏页比例低于设定值时,进入暂停循环,挂起主循环等待事件发生。
  • 版本更新

    InnoDB1.0.X版本引入了两个主要修改:

  • 增加参数控制刷新数量的百分比。
  • 修改脏页刷新比例,从90%降至75%。
  • InnoDB1.2.X进一步优化,将每秒和每十秒操作合并为一个判断流程:

  • 若InnoDB无事可做,则执行十秒操作;否则执行每秒操作。
  • 将刷新脏页任务交由单独线程处理。
  • 此优化使InnoDB线程结构更高效,减少主循环的负担。

    转载地址:http://tddfk.baihongyu.com/

    你可能感兴趣的文章
    Netty:原理架构解析
    查看>>
    Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
    查看>>
    Network Sniffer and Connection Analyzer
    查看>>
    Network 灰鸽宝典【目录】
    查看>>
    Networkx写入Shape文件
    查看>>
    NetworkX系列教程(11)-graph和其他数据格式转换
    查看>>
    Networkx读取军械调查-ITN综合传输网络?/读取GML文件
    查看>>
    network小学习
    查看>>
    Netwox网络工具使用详解
    查看>>
    Net与Flex入门
    查看>>
    net包之IPConn
    查看>>
    net发布的dll方法和类显示注释信息(字段说明信息)[图解]
    查看>>
    Net操作配置文件(Web.config|App.config)通用类
    查看>>
    NeurIPS(神经信息处理系统大会)-ChatGPT4o作答
    查看>>
    neuroph轻量级神经网络框架
    查看>>
    Neutron系列 : Neutron OVS OpenFlow 流表 和 L2 Population(7)
    查看>>
    NEW DATE()之参数传递
    查看>>
    New Relic——手机应用app开发达人的福利立即就到啦!
    查看>>
    new 一个button 然后dispose,最后这个button是null吗???
    查看>>
    next项目部署到服务器pm2进程守护
    查看>>