change buffer不仅不能给普通索引加速,还起到反作用的呢?

有没有哪些场景下,change buffer不仅不能给普通索引加速,还起到反作用的呢?

当需要更新一个数据页时,如果数据页在内存(buffer pool)中就直接更新好了(还要记下redo log),

但是 如果这个数据页还没有在内存中,并且不是唯一索引不用查是不是重了, InooDB 会将这些更新操作缓存在 change buffer 中(同样要记下redo log),

这样就不需要 从磁盘中 读入这个数据页了来更新了

好处:

语句的执行速度会得到明显的提升。

数据读入内存是需要占用 buffer pool 的,还能够避免占用内存,提高内存利用率。

虽然名字叫作 change buffer,实际上它是可以持久化的数据。也就是说,change buffer 在内存中有拷贝,也会被写入到磁盘上。

将 change buffer 中的操作应用到原数据页,得到最新结果的过程称为 merge。

时机是:

访问这个数据页会触发 merge

系统有后台线程会定期 merge。

在数据库正常关闭(shutdown)的过程中,会执行 merge 操作。

使用场景

change buffer 只限于用在普通索引的场景下,而不适用于唯一索引。

对唯一索引, 必须先查询看有没有已经存在, 才能改, 所以必须先把数据从磁盘读入内存, 这步不能省

那么,现在有一个问题就是:普通索引的所有场景,使用 change buffer 都可以起到加速作用吗?

merge 的时候是真正进行数据更新的时刻,而 change buffer 的主要目的就是将记录的变更动作缓存下来,所以在一个数据页做 merge 之前,change buffer 记录的变更越多(也就是这个页面上要更新的次数越多),收益就越大。

因此,对于写多读少的业务来说,页面在写完以后马上被访问到的概率比较小,此时 change buffer 的使用效果最好。

常见的就是 账单类、日志类的系统。

反过来,写入之后马上会做查询,那么即使满足了条件,将更新先记录在 change buffer,立即触发 merge 过程。

随机访问 IO 的次数不会减少,反而增加了 change buffer 的维护代价。

相关推荐
2301_803875613 小时前
PHP 中处理会话数组时的类型错误解析与修复指南
jvm·数据库·python
m0_743623923 小时前
c++如何批量修改文件后缀名_std--filesystem--replace_extension【实战】
jvm·数据库·python
2501_914245934 小时前
CSS如何处理CSS变量作用域冲突_利用特定类名重写变量值
jvm·数据库·python
maqr_1105 小时前
MySQL数据库迁移到云端如何保障安全_数据加密与SSL连接配置
jvm·数据库·python
u0109147605 小时前
MySQL如何限制触发器递归调用的深度_防止触发器死循环方法
jvm·数据库·python
weixin_381288185 小时前
MySQL中如何使用HEX函数转换十六进制_MySQL进制转换函数
jvm·数据库·python
Deitymoon5 小时前
嵌入式数据库——SQLite基础
数据库·sqlite
YMatrix 官方技术社区5 小时前
美国·硅谷|YMatrix 即将亮相 Postgres Conference 2026,前瞻 AI 时代的数据基座
数据库·数据仓库·postgresql·时序数据库·ymatrix
bKYP953cL5 小时前
构建自己的AI编程助手:基于RAG的上下文感知实现方案
数据库·人工智能·ai编程
Bert.Cai5 小时前
MySQL DML简介
数据库·mysql