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 的维护代价。

相关推荐
倔强的石头_16 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号35 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏5 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐5 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再5 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest5 天前
数据库SQL学习
数据库·sql