#MySQL# INNODB存储引擎之插入缓冲
发表于:2025-11-08 作者:千家信息网编辑
千家信息网最后更新 2025年11月08日,一 前言在 mysql的insert操作中,涉及到的需要insert 的 page有聚簇索引page,唯一索引page,以及非唯一索引page 。正常情况下,对于 聚簇索引( 自增作为主键 )的ins
千家信息网最后更新 2025年11月08日#MySQL# INNODB存储引擎之插入缓冲一 前言
在 mysql的insert操作中,涉及到的需要insert 的 page有聚簇索引page,唯一索引page,以及非唯一索引page 。正常情况下,
对于 聚簇索引( 自增作为主键 )的insert来说是一个顺序 io的操作,所以效率很好,当然,绑定主键的插入也是一个随机的,但这种情况比较少。
然而,对于非唯一的二级索引来说,绝大部分的插入是随机的IO过程,对于mysql来说,随机io的开销还是相对比较大的,InnoDB为此专门做了一项工作,那就是insert buffer
二 Insert BUFFER
1> insert buffer 是 BP当中有一块内存区域,并且和数据页一样,也有自己的物理页。
2> insert buffer bitmap存储着所有页的相关信息,每个页信息占用4字节。故一个bitmap页可以管理16384个页,之后再一个bitmap管理之后的page,以此类推
1. 该页的剩余空间比例,2字节
2. 该页是否有被缓存到insert buffer B+Tree中,1字节
3. 该页是否为索引页,1字节
insert bitmap存储在 系统表空间当中。
构造过程:
1 . 非唯一的二级索引页 的insert 操作,先判断该页是否在BP中,若不在,则 通过sapce offset构造search key ,并且通过该key将该页放到 insert buffer B+Tree中。
2 若在,则直接插入该页。
Merge过程:
1. select/update/delete操作若需要读取辅助索引页,则先在bitmap page中检查insert buffer b+Tree中是否有该页,若有改页,则先从insert buffer B+TRee读取该页merge到该辅助索引页中。
2. 对于insert 操作,若该辅助索引页不在BP中,则先检测 bitmap 页判断插入该 索引记录之后 该辅助索引页的空间是否小于1/32 页大小,若小于1/32,则强制读取该索引页,即进行 上面(1) 的操作,若不小于则直接插入到insert buffer中。
3. Master Thread 每隔1s 或者 10s会有insert buffer 的merge的相关操作,随机一个insert buffer B+Tree的位置然后顺序merge N个page。
参考:
《MySQL技术内幕:InnoDB存储引擎》
在 mysql的insert操作中,涉及到的需要insert 的 page有聚簇索引page,唯一索引page,以及非唯一索引page 。正常情况下,
对于 聚簇索引( 自增作为主键 )的insert来说是一个顺序 io的操作,所以效率很好,当然,绑定主键的插入也是一个随机的,但这种情况比较少。
然而,对于非唯一的二级索引来说,绝大部分的插入是随机的IO过程,对于mysql来说,随机io的开销还是相对比较大的,InnoDB为此专门做了一项工作,那就是insert buffer
二 Insert BUFFER
1> insert buffer 是 BP当中有一块内存区域,并且和数据页一样,也有自己的物理页。
2> insert buffer bitmap存储着所有页的相关信息,每个页信息占用4字节。故一个bitmap页可以管理16384个页,之后再一个bitmap管理之后的page,以此类推
1. 该页的剩余空间比例,2字节
2. 该页是否有被缓存到insert buffer B+Tree中,1字节
3. 该页是否为索引页,1字节
insert bitmap存储在 系统表空间当中。
构造过程:
1 . 非唯一的二级索引页 的insert 操作,先判断该页是否在BP中,若不在,则 通过sapce offset构造search key ,并且通过该key将该页放到 insert buffer B+Tree中。
2 若在,则直接插入该页。
Merge过程:
1. select/update/delete操作若需要读取辅助索引页,则先在bitmap page中检查insert buffer b+Tree中是否有该页,若有改页,则先从insert buffer B+TRee读取该页merge到该辅助索引页中。
2. 对于insert 操作,若该辅助索引页不在BP中,则先检测 bitmap 页判断插入该 索引记录之后 该辅助索引页的空间是否小于1/32 页大小,若小于1/32,则强制读取该索引页,即进行 上面(1) 的操作,若不小于则直接插入到insert buffer中。
3. Master Thread 每隔1s 或者 10s会有insert buffer 的merge的相关操作,随机一个insert buffer B+Tree的位置然后顺序merge N个page。
参考:
《MySQL技术内幕:InnoDB存储引擎》
索引
字节
辅助
存储
空间
过程
非唯
信息
情况
顺序
管理
引擎
较大
为此
以此类推
位置
内存
内幕
前言
区域
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
服务器管理器添加用户
云浮软件开发公司网站建设
魔兽怀旧服服务器里的盗贼
数据库的常用范式
北京金嘉泓达网络技术
泉州零工科技互联网有限公司
数据库检索的运算类型有哪些
网络安全考核评语
网络技术的交互性
网络安全防护体系包括哪些
服务器管理意义
遂宁软件开发培训机构
点读包安装说无法连接服务器
网络安全教育黑板报怎么画
重庆万盛网上生鲜软件开发
数据库课程设计源码
计算机算数服务器上市公司
配置连接远端数据库
台州市网络安全
bilibili无法连接服务器
光遇服务器可以换吗
浏览器下载服务器文件
查询出数据库中第一条的数据
淄川化工管理软件开发公司
excel安全检查数据库
软件开发项目验收制度
如何复制数据库表
网络服务器
steam 服务器无应答
神笔网络技术服务商