深入理解MySQL中MVCC与BufferPool缓存机制
来源:脚本之家
2022-12-29 10:32:49
0浏览
收藏
本篇文章向大家介绍《深入理解MySQL中MVCC与BufferPool缓存机制》,主要包括缓存、机制、MySQLMVCC、BufferPool,具有一定的参考价值,需要的朋友可以参考一下。
一、MVCC机制
- MVCC(Multi Version Concurrency Control),MySQL(默认)RR隔离级别就是通过该机制来保证的,对一行数据的读与写两个操作默认是不会通过加锁互斥来保证隔离性的
- 串行化隔离级别是为了保证较高的隔离性,是通过将所有操作加锁互斥来实现的
- MySQL在RC隔离级别和RR隔离级别下都实现了MVCC机制
- RC每次查询都会创建一个reade-view,而RR在创建完read-view之后,在不提交事务之前,每次查询还是第一次创建的read-view
undo日志版本链与read-view机制
- undo日志版本链是指一行数据被多个事务一次修改后,当每个事务修改完之后,MySQL会保留修改前的数据undo回滚日志,并且用两个隐藏字段trx_id和roll_pointer把只写undo日志串联起来形成一个历史记录版本链.
- RR隔离级别,当事务开启,执行任何SQL时会生成当前事务的read-view一致性视图,该视图在事务结束之前都不会变化(如果是RC隔离界别在每次执行查询SQL时都会重新生成最新的read-view),这个视图由执行查询时所有未提交的事务id数组(数组里最小的id为min_id)和已创建的最大事务id(max_id)组成,事务里任何SQL查询结果需要从对应版本链里的最新数据开始逐条跟read-view作比对,从而得到最终的结果
版本链比对规则
- 如果row的trx_id落在绿色部分(trx
- 如果row的trx_id落在红色部分(trx > max_id),表示这个版本是由将来启动的(未开始)事务生成的,是不可见的(若row的trx_id就是当前自己的事务是可见的)
- 如果 row 的 trx_id 落在黄色部分(min_id
- 若 row 的 trx_id 在视图数组中,表示这个版本是由还没提交的事务生成的不可见(若 row 的 trx_id 就是当前自己的事务是可见的)
- 若 row 的 trx_id 不在视图数组中,表示这个版本是已经提交了的事务生成的可见

二、BufferPool机制
InnoDB执行的BufferPool缓存机制:

InnoDB的SQL执行流程:
- 当客户端执行一条修改的SQL,需要经过Server层,再调用具体的执行引擎
- 加载数据页,把需要修改数据所在的数据页,缓存到BufferPool
- 修改前写undo日志,记录更改前数据,如果事务执行失败,使用undo日志进行数据回滚
- 更新BufferPool中的数据
- 准备提交事务写redo日志,保存操作记录。redo日志用来恢复已提交事务的BufferPool
- 准备提交事务写binlog日志,保存操作记录。binlog日志用来恢复磁盘数据
- 事务提交完成,此时binlog日志写入成功,并且在redo日志中记录了commit标记。事务提交完成后binlog日志和redo日志数据保持一致
- 数据持久化,IO线程不定期把BufferPool中的数据随机写入到磁盘,完成持久化
三、总结
MVCC实现机制(为什么同一个事务第一次查询出来之后,就算其它事务把新数据修改了,当前事务还是看到之前的数据)
- 它内部实际有个undo日志版本链,然后在事务第一次查询的时候,它会生成一个read-view一致性视图,然后我们后面所有查询的数据都会根据我们的那个undo日志版本链去跟我们当前的read-view里面按照一定的规则逐行去比对查找对应的数据
BufferPool机制:
- 数据库的增删改查都是直接操作BufferPool的,当我们执行一条修改的SQL经历过Server层之后会调用具体的执行引擎,然后将相关的数据页加载到BufferPool中,修改前写undo日志,记录修改前的数据为了方便事务失败之后的回滚,然后更新BufferPool,准备提交事务写redo日志保存操作记录,因为如果MySQL宕机了会从redo日志中将数据恢复到BufferPool中,然后会写binlog日志,保存操作记录,因为当我们删除数据库跑路时,binlog是用来恢复磁盘数据的,事务提交完成后,binlog日志写入成功,并且在redo日志记录提交标记,此时redo日志和binlog日志数据一致,而redo日志采用顺序IO写入,这样效率堪比内存操作。对于数据持久化,InnoDB会有个后台线程定时去将缓存刷到磁盘里
为什么MySQL不能直接更新磁盘上的数据而是设置了这么一套复杂的机制来执行SQL
- 因为来一个请求直接对磁盘文件进行随机读写,然后更新磁盘文件里的数据性能可能相当差.
- 因为磁盘随机读写的性能是非常差的,所以直接更新磁盘文件时不能让数据库抗住高并发的
- MySQL这套机制看起来很复杂,但它可以保证每个更新请求都是更新内存BufferPool,然后顺序写日志文件,同时还能保证各种异常情况下的数据一致性
- 更新内存的性能是极高的,然后顺序写磁盘上的日志文件的性能也是非常高的,要远高于随机读写磁盘文件,正是通过这套机制,才能让我们的MySQL数据库在较高配置的机器上每秒可以抗下几千甚至上完的读写请求
今天带大家了解了缓存、机制、MySQLMVCC、BufferPool的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
版本声明
本文转载于:脚本之家 如有侵犯,请联系study_golang@163.com删除
MySQL中where 1=1方法的使用及改进
- 上一篇
- MySQL中where 1=1方法的使用及改进
- 下一篇
- SQL使用复合索引实现数据库查询的优化
评论列表
-
- 贪玩的糖豆
- 这篇技术贴出现的刚刚好,太详细了,很棒,mark,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-03-29 23:59:21
-
- 虚心的蜗牛
- 写的不错,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢作者分享文章!
- 2023-03-15 23:58:53
-
- 淡然的蜜粉
- 太详细了,收藏了,感谢up主的这篇技术贴,我会继续支持!
- 2023-02-26 13:27:40
-
- 曾经的百褶裙
- 太详细了,已收藏,感谢博主的这篇技术贴,我会继续支持!
- 2023-01-17 03:09:06
-
- 懦弱的热狗
- 很好,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢楼主分享文章!
- 2023-01-11 23:51:38
-
- 激情的鸭子
- 这篇博文真及时,好细啊,写的不错,码起来,关注作者了!希望作者能多写数据库相关的文章。
- 2023-01-09 22:20:09
-
- 年轻的香氛
- 这篇技术文章太及时了,很详细,太给力了,已收藏,关注up主了!希望up主能多写数据库相关的文章。
- 2023-01-07 10:49:24
-
- 凶狠的小虾米
- 这篇文章真是及时雨啊,细节满满,很好,收藏了,关注师傅了!希望师傅能多写数据库相关的文章。
- 2023-01-05 21:14:01
-
- 文艺的小土豆
- 赞 ??,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢楼主分享文章!
- 2023-01-05 01:55:37
查看更多
最新文章
-
- 数据库 · MySQL | 1星期前 | MySQL · 慢查询 · 索引优化 · COUNT查询 · 汇总表 · 联合索引 覆盖索引 汇总表 MySQL COUNT慢 COUNT(*)优化
- MySQL COUNT(*) 总数查询变慢怎么办:从扫描行数到汇总表的完整治理流程
- 329浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
查看更多
AI推荐
-
- ljg-skills
- ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
- 2101次使用
-
- MELO音乐
- MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
- 1949次使用
-
- UniScribe
- UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
- 1888次使用
-
- 剧云
- 剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
- 2094次使用
-
- 万象有声
- 万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
- 2082次使用
查看更多
相关文章
-
- Redis 热 Key 治理实战:发现访问倾斜、拆分缓存和本地兜底
- 2026-06-13 111浏览
-
- redis实现多级缓存同步方案详解
- 2023-02-25 115浏览
-
- Go语言的反射机制详解
- 2022-12-28 126浏览
-
- 数据结构如何定义以及清理 例如订单的附带商品信息数据
- 2023-02-25 137浏览
-
- DCache 分布式存储系统|Set, ZSet 缓存模块的创建与使用
- 2023-02-17 139浏览

