MySQL多版本并发控制分析
程序员文章站
2024-01-03 15:31:22
...
今天我用MySQL验证这个问题的仔细研究了一下MySQL的后台实现,后来再网上发现了下面这篇文章非常就转过来,不过文中有些地方逻辑
背景:
之前面试被问到这么一个问题,数据库两个transaction,当transaction1在update某一行的时候,transaction2在select的时候会不会block。我以前用MySQL做过测试,印象是可以,但是面试官提出质疑,今天我用MySQL验证这个问题的仔细研究了一下MySQL的后台实现,后来再网上发现了下面这篇文章非常就转过来,不过文中有些地方逻辑上好像不太对,我没有时间去读MySQL源代码,就根据实际结果给出自己的推测,如果大家有明确答案请共享之。
我先把文中感觉不对的地方我自己总结的放出来(标红的为我的猜测),大家可以先看正文,然后再回头看我的总结:
正文链接如下:
Mysql到底是怎么实现MVCC的?这个问题无数人都在问,,但google中并无答案,本文尝试从Mysql源码中寻找答案。
在Mysql中MVCC是在Innodb存储引擎中得到支持的,Innodb为每行记录都实现了三个隐藏字段:
6字节的事物ID用来标识该行所述的事务,7字节的回滚指针需要了解下Innodb的事务模型。
1. Innodb的事务相关概念
为了支持事务,Innbodb引入了下面几个概念:
接下来请看第2页精彩内容:
推荐阅读
-
MySQL多版本并发控制分析
-
mysql的mvcc多版本统制
-
Go并发控制Channel使用场景分析
-
CentOS 7.x编译安装Nginx1.10.3+MySQL5.7.16+PHP5.2 5.3 5.4 5.5 5.6 7.0 7.1多版本全能环境
-
[MySQL] mysql 的读写锁与并发控制
-
MySQL-下载-安装-配置-多版本共存-设置密码-破解密码
-
MySQL 权限控制细节分析
-
MySQL 5.7并发复制隐式bug实例分析
-
CentOS 7.x编译安装Nginx1.10.3+MySQL5.7.16+PHP5.2 5.3 5.4 5.5 5.6 7.0 7.1多版本全能环境
-
MySQL 加锁控制并发的方法