Mysql的MVCC机制

本文涉及的产品
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: Mysql的MVCC机制

MVCC--多版本并发控制机制(Multi-Version Concurrency Control)

Mysql的MVCC指多版本并发控制,Myql在读已提交和可重复读隔离级别下都实现了MVCC机制。保证了mysql在RC和RR事务隔离级别下读取数据的隔离性。

MVCC由三部分组成实现:

undo日志:回滚日志,mysql每修改记录一次,无论是否提交均会按修改时间顺序把记录记在一个日志文件中,这个文件称为undo日志。

记录版本链:对于Innodb引擎的表中有三个隐藏字段,主键、操作事务id、回滚指针。如果表中没有可选的主键,那么会自动插入一个6B的主键。操作事务Id记录操作这条记录的事务Id。回滚指针指向该记录的上一个版本。这个记录共同构成了记录版本链表。undo日志存放的内容就是记录版本链。

read-view: 一致性视图,它记录的mysl当前的事务执行情况。主要有4个参数组成。    

MVCC的工作流程

 1. 开启事务,什么都没做。

 2. 执行第一个查询语句时生成read view视图,此时会生成一个16位的假事务Id。

 3. 执行第一个加锁的操作如增删改、当前读操作都会生成真正的事务Id,并获取最新的readview视图。

4. 再执行一次不加锁的查询,能否获取到最新的readview视图与事务隔离级别有关。

 4. 以当前事务Id、readview视图与记录的事务Id做对比,得出可查看的记录。

RC和RR隔离级别下MVCC的区别:

 1. RC隔离级别下每次查询均会生成新的readview视图,所以它能看所有提交的记录。

 2. RR隔离级别下只有第一次查询会生成readview视图,后面所有查询共用之前的readview视图。所以它读不到第一次查询后提交的数据。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
存储 关系型数据库 MySQL
MySQL数据库进阶第六篇(InnoDB引擎架构,事务原理,MVCC)
MySQL数据库进阶第六篇(InnoDB引擎架构,事务原理,MVCC)
|
1月前
|
存储 SQL 关系型数据库
MYSQL--锁机制*
MYSQL--锁机制*
|
1月前
|
关系型数据库 MySQL
mysql事务隔离级别MVCC
mysql事务隔离级别MVCC
|
1月前
|
存储 关系型数据库 MySQL
深入浅出MySQL事务管理与锁机制
MySQL事务确保数据一致性,ACID特性包括原子性、一致性、隔离性和持久性。InnoDB引擎支持行锁、间隙锁和临键锁,提供四种隔离级别。通过示例展示了如何开启事务、设置隔离级别以及避免死锁。理解这些机制对优化并发性能和避免数据异常至关重要。【6月更文挑战第22天】
107 3
|
1月前
|
存储 关系型数据库 MySQL
【MySQL技术内幕】4.5-Named File Formats机制
【MySQL技术内幕】4.5-Named File Formats机制
24 2
|
29天前
|
存储 关系型数据库 MySQL
重温MySQL的ACID实现原理:深入探索底层设计与机制
重温MySQL的ACID实现原理:深入探索底层设计与机制
|
1月前
|
SQL 关系型数据库 MySQL
【MySQL】事务?隔离级别?锁?详解MySQL并发控制机制
【MySQL】事务?隔离级别?锁?详解MySQL并发控制机制
48 0
|
2月前
|
存储 关系型数据库 MySQL
MySQL的锁机制
MySQL的锁机制主要用于管理并发事务对数据的一致性和完整性的访问控制
40 4
|
2月前
|
存储 关系型数据库 MySQL
MySQL数据库锁定机制
MySQL数据库锁定机制
24 0
|
2月前
|
SQL 关系型数据库 MySQL