概览
- 一. 多版本并发控制(MVCC)
- 1.概述
- 2.InnoDB的MVCC
- 二.MySql的存储引擎
一. 多版本并发控制(MVCC)
1.概述
可以认为MVCC是行级锁的一个变种,其在很多情况下避免了加锁操作,因此开销更低。
不同存储引擎的MVCC实现是不同的,但大部分实现了非阻塞的读操作,写操作也只锁定必要的行。
MVCC的实现,是通过保存数据在某个时间点的快照来实现的。即不管需要执行多长时间,每个事务看到的数据都是一致的
2.InnoDB的MVCC
- 在每行记录后面保存两个隐藏的列,一个保存了行的创建时间,一个保存行的过期时间(或删除时间)。
- 注意存储的并不是实际的时间值,而是系统版本号(system version number)
- 每开始一个新的事务,系统版本号都会自动递增
- 事务开始时刻的系统版本号会作为事务的版本号,用来和查询到的每行记录的版本号进行比较
REPEATABLE READ隔离级别下的MVCC
优点:
- 保存这两个额外系统版本号,使大多数读操作都可以不用加锁。
- 读数据操作很简单,性能很好,并且也能保证只会读取到符合标准的行
缺点:
- 每行记录都需要额外的存储空间,需要做更多的行检查工作,以及一些额外的维护工作
注意:
- MVCC只在REPEATABLE READ和READ COMMITTED两个隔离级别下工作。
- 其他两个隔离级别都和MVCC不兼容:
READ UNCOMMITTED总是读取最新的数据行,不是符合当前事务版本的数据行;而SERIALIZABLE则会对所有读取的行都加锁