Mysql(1)并发控制

来源:互联网 发布:电脑编程 编辑:程序博客网 时间:2024/06/05 04:13

1、读写锁

读锁是共享锁,相互不阻塞的。

写锁是排他锁,一个写锁会阻塞其他的写锁和读锁。

2、锁粒度

所谓的锁策略,就是在锁的开销和数据的安全性之间寻求平衡,这种平衡当然也会影响到性能。大多数商用数据库系统没有提供更多的选择,一般都是在表上施加行级锁,并加以各种复杂的方式来实现,以便在锁比较多的情况下尽可能地提供更好的性能。

Mysql每种存储引擎都可以实现自己的锁策略和锁粒度。


锁策略一:表锁

表锁是Mysql中最基本的锁策略,并且开销是最小的。一个用户对表进行写操作前,需要先获取写锁,这会阻塞其他用户对表的写和读操作。

        写锁也比读锁有更高的优先级,因此一个写锁请求可能会被插入到读锁队列的前面

        尽管存储引擎可以管理自己的锁,mysql本身还是会使用各种有效的表锁来实现不同的目的。例如,服务器会为诸如alter table之类的语句使用表锁,而忽略存储引擎的锁机制。


锁策略二:行级锁

行级锁可以最大程度地支持并发处理,同时也带来 最大的锁开销。行级锁只在存储引擎层实现,而mysql服务器层没有实现。服务器层完全不了解存储引擎的锁实现。