当前位置: 首页 > article >正文

MySQL45讲 第十二讲 为什么我的MySQL会“抖”一下?

文章目录

  • MySQL45讲 第十二讲 为什么我的MySQL会“抖”一下?
    • 一、问题引入
    • 二、MySQL “抖” 的原因:刷脏页操作
      • (一)脏页的概念
      • (二)引发刷脏页(flush)的场景
    • 三、InnoDB 刷脏页的控制策略
      • (一)设置 innodb_io_capacity 参数
      • (二)根据脏页比例和 redo log 写盘速度控制刷盘速度
      • (三)innodb_flush_neighbors 参数对刷脏页的影响
    • 四、总结与建议

MySQL45讲 第十二讲 为什么我的MySQL会“抖”一下?


一、问题引入

在日常使用 MySQL 时,可能会遇到 SQL 语句执行速度不稳定的情况,有时正常执行很快,但偶尔会突然变慢,就像数据库 “抖” 了一下。这篇文章将深入探究这种现象背后的原因以及应对方法。


二、MySQL “抖” 的原因:刷脏页操作

(一)脏页的概念

  1. 当内存数据页与磁盘数据页内容不一致时,内存页被称为 “脏页”;内存数据写入磁盘后,内存和磁盘上的数据页内容一致,称为 “干净页”。在 MySQL 中,InnoDB 处理更新语句时,先写内存和 redo log(重做日志),然后返回给客户端更新成功,而将内存数据写入磁盘的过程称为 flush。

(二)引发刷脏页(flush)的场景

  1. redo log 写满

    • 对应场景:类似咸亨酒店掌柜粉板记满赊账记录。

    • 原理:此时系统停止更新操作,推进 checkpoint,将 checkpoint 位置修改前的日志对应的脏页 flush 到磁盘,为 redo log 腾出空间。若不及时处理,更新操作将被阻塞,更新数会跌为 0。

      在这里插入图片描述

  2. 内存不足

    • 对应场景:掌柜记忆有限,事情太多时需将账先记入账本。
    • 原理:InnoDB 用缓冲池管理内存,缓冲池内存页有未使用、干净页、脏页三种状态。长时间运行的库未使用页面少,当需要新内存页而内存不够时,淘汰最久不使用的数据页,若为脏页则先刷到磁盘。若一个查询要淘汰的脏页个数过多,会导致查询响应时间变长。
  3. MySQL 认为系统 “空闲” 时

    • 对应场景:生意不忙或打烊后掌柜更新账本。
    • 原理:MySQL 会利用空闲时间刷脏页,但此场景对性能影响相对较小,因为系统此时压力不大。
  4. MySQL 正常关闭时

    • 对应场景:年底酒店关门结清账目。
    • 原理:MySQL 正常关闭时会将内存脏页 flush 到磁盘,以便下次启动时能快速从磁盘读数据,此场景下性能影响可忽略不计。

三、InnoDB 刷脏页的控制策略

(一)设置 innodb_io_capacity 参数

  1. 该参数用于告知 InnoDB 所在主机的 IO 能力,建议设置为磁盘的 IOPS(可通过 fio 工具测试)。若设置不当,如某公司案例中 SSD 磁盘但 innodb_io_capacity 设置为 300,会导致 InnoDB 刷脏页过慢,脏页累积,影响查询和更新性能。

(二)根据脏页比例和 redo log 写盘速度控制刷盘速度

  1. 计算参考因素
    • 脏页比例:参数 innodb_max_dirty_pages_pct 默认值 75% 为脏页比例上限。InnoDB 根据当前脏页比例(假设为 M)算出 0 - 100 之间数字,伪代码为若 M>=innodb_max_dirty_pages_pct 则返回 100,否则返回 100*M/innodb_max_dirty_pages_pct。
    • redo log 写盘速度:InnoDB 每次写入日志有序号,当前写入序号与 checkpoint 对应序号差值假设为 N,根据 N 算出 0 - 100 之间数字(F2 (N) 算法较复杂,N 越大值越大)。
  2. 计算刷盘速度
    • 取上述根据脏页比例和 redo log 写盘速度算出的两个数字(F1 (M) 和 F2 (N))中较大值记为 R,引擎按 innodb_io_capacity 定义能力乘以 R% 控制刷脏页速度。

(三)innodb_flush_neighbors 参数对刷脏页的影响

  1. 该参数控制刷脏页时是否连带 “邻居” 脏页一起刷。值为 1 时,准备刷一个脏页时,若旁边数据页是脏页会一起刷,逻辑可蔓延;值为 0 时不找邻居,自己刷自己。在机械硬盘时代,找 “邻居” 可减少随机 IO 提升性能,但使用 SSD 等 IOPS 高的设备时,建议设为 0,可减少 SQL 语句响应时间。MySQL 8.0 中默认值已为 0。

四、总结与建议

  1. MySQL “抖” 一下的原因主要是刷脏页操作,其在 redo log 写满、内存不足、系统空闲、正常关闭等场景下触发,其中前两种场景可能影响性能。
  2. 应对策略包括合理设置 innodb_io_capacity 参数,关注脏页比例(通过 Innodb_buffer_pool_pages_dirty/Innodb_buffer_pool_pages_total 获取)避免接近 75%,根据存储设备类型合理设置 innodb_flush_neighbors 参数。通过这些方法可优化 MySQL 性能,减少 “抖动” 现象对业务的影响。

http://www.kler.cn/a/378841.html

相关文章:

  • K8s学习
  • 2024年博客之星年度评选—创作影响力评审入围名单公布
  • 微服务学习:基础理论
  • 【王树森搜素引擎技术】相关性03:文本匹配(TF-IDF、BM25、词距)
  • 天机学堂5-XxlJobRedis
  • 【Web】2025西湖论剑·中国杭州网络安全安全技能大赛题解(全)
  • 大数据新视界 -- 大数据大厂之提升 Impala 查询效率:索引优化的秘籍大揭秘(上)(3/30)
  • 「iOS」——知乎日报一二周总结
  • STL学习-关联容器-pair数对
  • 新老项目不同node版本,使用nvm控制node版本切换(mac、window)
  • Excel菜单选项无法点击?两种原因及解决方法全解析
  • 《Python 练习一百题:提升编程技能的宝藏》
  • 重生之我在Java世界------学工厂设计模式
  • Transformer 架构简单理解;GPT-3.5 的架构,向量长度为 :12288;Transformer架构改进:BERT和GPT
  • git创建一个公共子模块用于不同的项目共享这一个子模块
  • JWT-混淆算法
  • 鸿蒙HarmonyOS应用开发者(基础+高级)认证
  • uniapp下载文件的方案,包括H5,App方案解决办法
  • 如何使用Python WebDriver爬取ChatGPT内容(完整教程)
  • 数据结构,问题 C: 后缀表达式
  • Java NIO 【处理消息边界】
  • 基于 Spring Boot 和 Vue 的大学生入伍管理创新系统
  • CSS中display和visibility的区别
  • pnpm install安装element-plus的版本跟package.json指定的版本不一样
  • Hive SQL 和 SQL 的区别总结(持续更新中.....)
  • UV紫外相机