MySQL MVCC实现及其机制(转载)
来源:互联网 发布:杭州牛盾网络 编辑:程序博客网 时间:2024/04/29 13:26
多版本并发控制
Multiversion Concurrency Control
大部分的MySQL的存储 引擎,比如InnoDB,Falcon,以及PBXT并不是简简单单的使用行锁机制。它们都使用了行锁结合一种提高并发的技术,被称为MVCC(多版本并 发控制)。MVCC并不单单应用在MySQL中,其他的数据库如Oracle,PostgreSQL,以及其他数据库也使用这个技术。
MVCC避免了许多需要加锁的情形以及降低消耗。这取决于它实现的方式,它允许非阻塞读取,在写的操作的时候阻塞必要的记录。
MVCC保存了某一时刻数据的一个快照。意思就是无论事务运行了多久,它们都能看到一致的数据。也就是说在相同的时间下,不同的事务看相同表的数据是不同的。如果你从来没有这方面的经验,可能说这些有点令人困惑。但是在以后这个会很容易理解和熟悉的。
每个存储引擎实现MVCC方式都是不同的。有许多种包含了乐观(optimistic)和悲观(pessimistic)的并发控制。我们用简单的InnoDb的行为来举例说明MVCC工作方式。
InnoDB实现MVCC的方法是,它存储了每一行的两个额外的隐藏字段,这两个隐藏字段分别记录了行的创建的时间和删除的时间。在每个事件发生的时候,每行存储版本号,而不是存储事件实际发生的时间。每次事务的开始这个版本号都会增加。自记录时间开始,每个事务都会保存记录的系统版本号。依照事务的版本来检查每行的版本号。在事务隔离级别为可重复读的情况下,来看看怎样应用它。
SELECT
InnoDB检查每行,要确定它符合两个标准:
InnoDB必须知道行的版本号,这个行的版本号至少要和事务版本号一样的老。(也就是是说它的版本号可能少于或者和事务版本号相同)。这个既能确定事物开始之前行是存在的,也能确定事物创建或修改了这行。
行的删除操作的版本一定是未定义的或者大于事物的版本号。确定了事物开始之前,行没有被删除。
符合了以上两点。会返回查询结果。
INSERT
InnoDB记录了当前新增行的系统版本号。
DELETE
InnoDB记录的删除行的系统版本号作为行的删除ID。
UPDATE
InnoDB复制了一行。这个新行的版本号使用了系统版本号。它也把系统版本号作为了删除行的版本。
所有其他记录的结果保存是,从未获得锁的查询。这样它们查询的数据就会尽可能的快。要确定查询行要遵循这些标准。缺点是存储引擎要为每一行存储更多的数据,检查行的时候要做更多的处理以及其他内部的一些操作。
MVCC只能在可重复读和可提交读的隔离级别下生效。不可提交读不能使用它的原因是不能读取符合事务版本的行版本。它们总是读取最新的行版本。可序列化不能使用MVCC的原因是,它总是要锁定行。
下面的表说明了在MySQL中不同锁的模式以及并发级别。
锁的策略 并发性 开销 引擎
表 最低 最低 MyISAM,Merge,Memory
行 高 高 NDB Cluster
行和MVCC 最高 最高 InnoDB,Falcon,PBXT,solidD
- MySQL MVCC实现及其机制(转载)
- MYSQL MVCC实现及其机制
- MYSQL MVCC实现及其机制
- MYSQL MVCC实现及其机制
- MYSQL MVCC实现及其机制
- MYSQL MVCC 实现机制
- 理解MYSQL MVCC 实现机制
- 轻松理解MYSQL MVCC 实现机制
- 轻松理解MYSQL MVCC 实现机制
- 轻松理解MYSQL MVCC 实现机制
- 轻松理解MySql MVCC 实现机制
- innodb mvcc实现机制
- MVCC实现-MYSQL INNODB MVCC实现
- MYSQL MVCC 实现原理
- MySQL InnoDB MVCC实现原理
- MySQL InnoDB MVCC实现原理
- mysql MVCC之InnoDB实现
- Mysql MVCC实现原理解析
- B树系列文章(2)--插入操作(摘自老杨)
- wxWidgets 编译, 工程部署, 自动build, 完整build 和设置工程
- 删除表中某字段重复记录
- gsoap开发webService
- SQL Server和Oracle的常用函数对比
- MySQL MVCC实现及其机制(转载)
- 12岁男孩发现Firefox严重漏洞获奖3000美元
- B树系列文章(3)--删除、更新操作(摘自老杨)
- InheritableThreadLocal的认识--一种可继承的ThreadLocal
- Linux开启SSH服务命令
- dbgrideh、dxdbgrid和cxgrid保留上次的列宽、列序
- 解决struts拦截fckeditor的问题
- Screen屏幕定義,常用程式開發
- 让lampp的nobody用户可执行远程需root权限的命令