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
相关文章
|
2月前
|
SQL 关系型数据库 MySQL
MySQL数据库,可以使用二进制日志(binary log)进行时间点恢复
对于MySQL数据库,可以使用二进制日志(binary log)进行时间点恢复。二进制日志是MySQL中记录所有数据库更改操作的日志文件。要进行时间点恢复,您需要执行以下步骤: 1. 确保MySQL配置文件中启用了二进制日志功能。在配置文件(通常是my.cnf或my.ini)中找到以下行,并确保没有被注释掉: Copy code log_bin = /path/to/binary/log/file 2. 在需要进行恢复的时间点之前创建一个数据库备份。这将作为恢复的基准。 3. 找到您要恢复到的时间点的二进制日志文件和位置。可以通过执行以下命令来查看当前的二进制日志文件和位
102 1
|
3月前
|
SQL 存储 关系型数据库
redo log 的执行流程?
redo log 的执行流程?
|
3月前
|
关系型数据库 MySQL 数据库
MySQL 的 change buffer 是什么?
MySQL 的 change buffer 是什么?
|
2月前
|
存储 SQL 关系型数据库
[MySQL]事务原理之redo log,undo log
[MySQL]事务原理之redo log,undo log
|
2月前
|
SQL 缓存 关系型数据库
MySQL的万字总结(缓存,索引,Explain,事务,redo日志等)
MySQL的万字总结(缓存,索引,Explain,事务,redo日志等)
68 0
|
3月前
|
数据库
redo log日志格式
redo log日志格式
|
3月前
|
关系型数据库 MySQL
MySQL学习笔记
MySQL学习笔记
|
3月前
|
安全 关系型数据库 MySQL
某教程学习笔记(一):09、MYSQL数据库漏洞
某教程学习笔记(一):09、MYSQL数据库漏洞
20 0
|
23天前
|
安全 Linux 网络安全
/var/log/secure日志详解
Linux系统的 `/var/log/secure` 文件记录安全相关消息,包括身份验证和授权尝试。它涵盖用户登录(成功或失败)、`sudo` 使用、账户锁定解锁及其他安全事件和PAM错误。例如,SSH登录成功会显示"Accepted password",失败则显示"Failed password"。查看此文件可使用 `tail -f /var/log/secure`,但通常只有root用户有权访问。
69 4
|
1天前
|
XML Java Maven
Springboot整合与使用log4j2日志框架【详解版】
该文介绍了如何在Spring Boot中切换默认的LogBack日志系统至Log4j2。首先,需要在Maven依赖中排除`spring-boot-starter-logging`并引入`spring-boot-starter-log4j2`。其次,创建`log4j2-spring.xml`配置文件放在`src/main/resources`下,配置包括控制台和文件的日志输出、日志格式和文件切分策略。此外,可通过在不同环境的`application.yml`中指定不同的log4j2配置文件。最后,文章提到通过示例代码解释了日志格式中的各种占位符含义。