绝对最直白的 MySQL MVCC 机制总结,免费拿走

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 最直白的 MySQL MVCC 机制总结

网络异常,图片无法展示
|

🍁 作者:知识浅谈,CSDN 签约讲师,后端领域优质创作者,阿里云社区技术博主,热爱分享创作

📌 擅长领域:全栈工程师、爬虫、ACM 算法

💒 公众号:知识浅谈

🔥  联系方式 vx:zsqtcc


绝对最直白的 MySQL MVCC 机制总结

🤞开胃小菜🤞

  • 在小 ySQL InnoDB 存储擎下 RC(读已提交,RR(可重复读)基于 MVCC(多版本并发控制)进行并发事务控制
  • MVCC 是基于”数据版本”对并发事务进行访问。

🎈举例子引题

事务集合:

事务 A:设置 id=1088 的 name 为张三

事务 B:设置 id=1088 的 name 为张小三

事务 C:设置 id=1088 的 name 为张老三

事务 D:两次查询 id=1088 的名字


网络异常,图片无法展示
|


前三个事务分别进行了修改的操作,最后一个事务只有查询的操作。

RR 级别:事务 D 的第一条 Select 查询结果为张三,第二条查询结果也为张三。

RC 级别: 事务 D 的第一条 Select 查询结果为张三,第二条查询结果也为张小三。因为 RC 级别下不可重复读,所以两次结果不一样,具体原因看到后边就懂了,先提一下,主要是因为 RR 级别只生成一个 ReadView(快照)

🎈UNDO_LOG 版本链

undolog就是undolog日志。基于 UNDO_LOG 版本链如下:


网络异常,图片无法展示
|


版本链解析:在原来的字段基础上加上 TRX_IDDB_ROLL_PTRTRX_ID 是 此次修改的事务idDB_ROLL_PTR是指向上一个修改的版本指针

🏹注意点

UNDO LOG 不是会被删除吗❓

中间数据万一被删了版本链不就断了❓答:

  • UNDO LOG 版本链不是立即删除,
  • MySQL 确保版本链数据不再被“引用”后再进行删除。

🎈ReadView 是啥

上边给大家留了一个问题,Readview 是什么,我们来看看


📙ReadView 是“快照读”SQL 执行时 MVCC 提取数据的依据。

  • 快照读就是最普通的 Selecti 查询 SQL 语句
  • 当前读指代执行下列语句时进行数据读取的方式,如 Insert、.Update、Delete、Select...for update、Select...lock in share mode


📙ReadView,是一个数据结构,包含 4 个字段

  • mids:当前活跃的事务编号集合
  • min_trx_id:最小活跃事务编号
  • max_trx_id:预分配事务编号,当前最大事务编号+1
  • creator trx id:ReadView 创建者的事务编号

🍮RC 与 ReadView 的关系

RC(读已提交):在每一次执行快照读的时候都会生成一个新的 ReadView


结合上边的例子来理解


  • RC 与 ReadView

  • 拿第一次的来分析,结合右边的规则和 ReadView 对版本链进行从上到下比对,选择合适的版本取出对应的值即可。

  • 拿第二次 select 的来分析,结合右边的规则和 ReadView 对版本链进行从上到下比对,选择合适的版本取出对应的值即可。

🍮RC 与 ReadView 的关系

RR(可重复读):仅仅在第一次执行快照读的时候生成 ReadView,后续快照读服用之前生成的。(有例外:就是两次快照读中间有当前读的时候,就不会有两次快照读的 ReadView 就不一样了)


结合上边的例子来理解


网络异常,图片无法展示
|


RR 级别下使用 MVCC 能避免幻读吗❓

答:能,但不完全能!为何能🥕

  • 连续多次快照读,ReadView 会产生复用,没有幻读问题
  • 特例:当两次快照读之间存在当前读,ReadView 会重新生成,导致产生幻读

🍚总结

终于写完了,这个总结我是弄懂了之后才发出来的,仔细看图片中的每一句话,相信你会有所收获。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
存储 关系型数据库 MySQL
MySQL MVCC全面解读:掌握并发控制的核心机制
【10月更文挑战第15天】 在数据库管理系统中,MySQL的InnoDB存储引擎采用了一种称为MVCC(Multi-Version Concurrency Control,多版本并发控制)的技术来处理事务的并发访问。MVCC不仅提高了数据库的并发性能,还保证了事务的隔离性。本文将深入探讨MySQL中的MVCC机制,为你在面试中遇到的相关问题提供全面的解答。
317 2
|
3月前
|
缓存 关系型数据库 MySQL
MySQL并发支撑底层Buffer Pool机制详解
【10月更文挑战第18天】在数据库系统中,磁盘IO操作是性能瓶颈之一。为了提高数据访问速度,减少磁盘IO,MySQL引入了缓存机制。其中,Buffer Pool是InnoDB存储引擎中用于缓存磁盘上的数据页和索引页的内存区域。通过缓存频繁访问的数据和索引,Buffer Pool能够显著提高数据库的读写性能。
227 2
|
11天前
|
SQL 存储 关系型数据库
MySQL进阶突击系列(05)突击MVCC核心原理 | 左右护法ReadView视图和undoLog版本链强强联合
2024年小结:感谢阿里云开发者社区每月的分享交流活动,支持持续学习和进步。过去五个月投稿29篇,其中17篇获高分认可。本文详细介绍了MySQL InnoDB存储引擎的MVCC机制,包括数据版本链、readView视图及解决脏读、不可重复读、幻读问题的demo演示。
|
4月前
|
canal 消息中间件 关系型数据库
Canal作为一款高效、可靠的数据同步工具,凭借其基于MySQL binlog的增量同步机制,在数据同步领域展现了强大的应用价值
【9月更文挑战第1天】Canal作为一款高效、可靠的数据同步工具,凭借其基于MySQL binlog的增量同步机制,在数据同步领域展现了强大的应用价值
930 4
|
2月前
|
存储 关系型数据库 MySQL
MySQL MVCC深度解析:掌握并发控制的艺术
【10月更文挑战第23天】 在数据库领域,MVCC(Multi-Version Concurrency Control,多版本并发控制)是一种重要的并发控制机制,它允许多个事务并发执行而不产生冲突。MySQL作为广泛使用的数据库系统,其InnoDB存储引擎就采用了MVCC来处理事务。本文将深入探讨MySQL中的MVCC机制,帮助你在面试中自信应对相关问题。
218 3
|
3月前
|
存储 关系型数据库 MySQL
优化 MySQL 的锁机制以提高并发性能
【10月更文挑战第16天】优化 MySQL 锁机制需要综合考虑多个因素,根据具体的应用场景和需求进行针对性的调整。通过不断地优化和改进,可以提高数据库的并发性能,提升系统的整体效率。
201 1
|
4月前
|
关系型数据库 MySQL 数据库
MySQL高级篇——MVCC多版本并发控制
什么是MVCC、快照读与当前读、隐藏字段、Undo Log版本链、ReadView、举例说明、InnoDB 解决幻读问题
|
4月前
|
监控 关系型数据库 MySQL
MySQL锁机制与解决死锁问题
MySQL锁机制与解决死锁问题
383 5
|
4月前
|
存储 关系型数据库 MySQL
深入解析MySQL数据存储机制:从表结构到物理存储
深入解析MySQL数据存储机制:从表结构到物理存储
483 1
|
4月前
|
存储 SQL 关系型数据库
MySQL 的锁机制,那么多的锁,该怎么区分?
MySQL 的锁机制,那么多的锁,该怎么区分?
54 0