MVCC多版本并发

MVCC是一种提高数据库并发性能的技术,常用于InnoDB存储引擎。它结合行锁与行的多个版本,允许非锁定读取,减少锁冲突。共享锁(读锁)允许多个读操作并行,排它锁(写锁)则独占资源。MySQL的锁粒度包括页级、表级和行级,行级锁提供最高并发,但也可能导致死锁。MyISAM使用表级锁,而InnoDB默认行级锁。
摘要由CSDN通过智能技术生成

概念

MVCC (Multiversion Concurrency Control),即多版本并发控制技术,是一种提高并发的技术。它使得大部分支持行锁的事务引擎,不再单纯的用行锁来进行数据库的并发控制,它把数据库的行锁与行的多个版本结合起来,只需要很小的开销就可以实现非锁定读,从而大大提高数据库系统的并发性能。

共享锁和排它锁

也叫读锁和写锁。读锁是共享的,不会阻塞其它读锁读数据,但会阻塞其它写锁;写锁是排它的,一个写锁会阻塞其它锁,不管是读锁还是写锁。

共享锁(S锁)

又称读锁,若事务T对数据对象A加上S锁,则事务T可以读A但不能修改A,其他事务只能再对A加S锁,而不能加X锁,直到T释放A上的S锁。

这保证了其他事务可以读A,但在T释放A上的S锁之前不能对A做任何修改。

排它锁(X锁)

又称写锁。若事务T对数据对象A加上X锁,事务T可以读A也可以修改A,其他事务不能再对A加任何锁,直到T释放A上的锁。

这保证了其他事务在T释放A上的锁之前不能再读取和修改A。

锁粒度

MySQL有三种锁级别:页级、表级、行级。

MyISAM和MEMORY存储引擎用的是表级锁(table-level locking);InnoDB存储引擎既支持行级锁(row-level locking),也支持表级锁,但默认情况下是采用行级锁。

MySQL这3种锁的特性可大致归纳如下:

表级锁:锁定粒度大,发生锁冲突的概率最高,开销小,并发度最低,不会出现死锁;

行级锁:锁定粒度最小,发生锁冲突的概率最低,开销大,并发度最高,会出现死锁;

页面锁:锁定粒度界于表锁和行锁之间,并发度一般,也会出现死锁;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值