MySQL学习笔记-change buffer 和 redo log

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: MySQL学习笔记-change buffer 和 redo log

在给 MySQL 建立二级索引的时候,从唯一性约束来说可以分为普通索引唯一索引,但你知道这两种索引在查询更新数据的时候性能有什么区别吗?然后 change bufferredo log 的联系是什么呢?这篇文章就来学习一下普通索引唯一索引的区别,以及涉及到的change bufferredo log的联系。

1.笔记图

2.索引类型对查询性能的影响


  • select id from T where k=5
  • 普通索引:对于普通索引来说,查找到满足条件的第一个记录 (5,500) 后,需要查找下一个记录,直到第一个不满足 k=5 条件的记录
  • 唯一索引:对于唯一索引来说,由于索引定义了唯一性,查找到第一个满足条件的记录后,就会停止继续检索

Tips:两者查询性能差距微乎其微。

3.索引类型对更新性能的影响

  • change buffer
  • 当需要更新一个数据页时,如果数据页在内存中就直接更新
  • 如果数据页还没有在内存中的话,在不影响数据一致性的前提下,InnoDB 会将这些更新操作缓存在 change buffer
  • 下次查询需要访问这个数据页的时候,将数据页读入内存,然后执行 change buffer 中与这个页有关的操作
  • change buffer 在内存中有拷贝,也会被写入到磁盘上
  • 将更新操作先记录在 change buffer,减少读磁盘,语句的执行速度会得到明显的提升,数据读入内存是需要占用 buffer pool 的,这种方式还能够避免占用内存,提高内存利用率
  • merge
  • change buffer 中的操作应用到原数据页,得到最新结果的过程称为 merge
  • 访问数据页会触发 merge,系统有后台线程会定期 merge
  • 在数据库正常关闭(shutdown)的过程中,也会执行 merge
  • 什么条件下可以使用 change buffer?
  • 普通索引
  • 普通索引的更新可以使用 change buffer
  • change buffer 的大小,可以通过参数 innodb_change_buffer_max_size 来动态设置,这个参数设置为 50 的时候,表示 change buffer 的大小最多只能占用 buffer pool50%
  • 唯一索引:对于唯一索引来说,所有的更新操作都要先判断这个操作是否违反唯一性约束,唯一索引的更新就不能使用 change buffer

4.普通索引和唯一索引该怎么选择

  • 这两种索引在查询能力上是没差别的,主要考虑的是对更新性能的影响,由于唯一索引不能使用到 change buffer,索引尽量使用普通索引
  • 如果所有的更新后面,都马上伴随着对这个记录的查询,应该关闭 change buffer
  • 普通索引和 change buffer 的配合使用,对于数据量大的表的更新优化还是很明显的

5.change buffer 和 redo log

  • 插入数据:insert into t(id,k) values(id1,k1),(id2,k2);

  • 假设当前 k 索引树的状态,查找到位置后,k1 所在的数据页在内存 (InnoDB buffer pool) 中,k2 所在的数据页不在内存中
  • Page 1 在内存中,直接更新内存
  • Page 2 没有在内存中,就在内存的 change buffer 区域,记录下 我要往 Page 2 插入一行 这个信息
    将上述两个动作记入 redo log
  • 查询数据:select * from t where k in (k1, k2)

  • Page 1 的时候,直接从内存返回
  • Page 2 的时候,需要把 Page 2 从磁盘读入内存中,然后应用 change buffer 里面的操作日志,生成一个正确的版本并返回结果
  • redo log 主要节省的是随机写磁盘的 IO 消耗(转成顺序写),而 change buffer 主要节省的则是随机读磁盘的 IO 消耗
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6天前
|
监控 关系型数据库 MySQL
《MySQL 简易速速上手小册》第7章:MySQL监控和日志分析(2024 最新版)
《MySQL 简易速速上手小册》第7章:MySQL监控和日志分析(2024 最新版)
43 3
|
4天前
|
关系型数据库 MySQL 数据库
mysql数据库bin-log日志管理
mysql数据库bin-log日志管理
|
6天前
|
关系型数据库 MySQL 数据管理
MySQL通过 bin-log 恢复从备份点到灾难点之间数据
MySQL通过 bin-log 恢复从备份点到灾难点之间数据
191 0
|
6天前
|
DataWorks 关系型数据库 MySQL
DataWorks产品使用合集之在DataWorks中,如何通过PolarDB for MySQL来查看binlog日志
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
33 1
|
6天前
|
SQL 监控 关系型数据库
【MySQL学习】MySQL的慢查询日志和错误日志
【MySQL学习】MySQL的慢查询日志和错误日志
|
6天前
|
SQL 存储 关系型数据库
MySQL慢日志的介绍以及如何使用问题
MySQL慢日志的介绍以及如何使用问题
23 0
|
6天前
|
存储 SQL 关系型数据库
mysql数据库日志
mysql数据库日志
|
4天前
|
存储 关系型数据库 数据库
关系型数据库文件方式存储LOG FILE(日志文件)
【5月更文挑战第11天】关系型数据库文件方式存储LOG FILE(日志文件)
16 1
|
5天前
|
运维 监控 安全
Java一分钟之-Log4j与日志记录的重要性
【5月更文挑战第16天】Log4j是Java常用的日志框架,用于灵活地记录程序状态和调试问题。通过设置日志级别和过滤器,可避免日志输出混乱。为防止日志文件过大,可配置滚动策略。关注日志安全性,如Log4j 2.x的CVE-2021-44228漏洞,及时更新至安全版本。合理使用日志能提升故障排查和系统监控效率。
27 0
|
6天前
|
C++
JNI Log 日志输出
JNI Log 日志输出
21 1