1、读写锁
读锁是共享锁,相互不阻塞的。
写锁是排他锁,一个写锁会阻塞其他的写锁和读锁。
2、锁粒度
所谓的锁策略,就是在锁的开销和数据的安全性之间寻求平衡,这种平衡当然也会影响到性能。大多数商用数据库系统没有提供更多的选择,一般都是在表上施加行级锁,并加以各种复杂的方式来实现,以便在锁比较多的情况下尽可能地提供更好的性能。
Mysql每种存储引擎都可以实现自己的锁策略和锁粒度。
锁策略一:表锁
表锁是Mysql中最基本的锁策略,并且开销是最小的。一个用户对表进行写操作前,需要先获取写锁,这会阻塞其他用户对表的写和读操作。
写锁也比读锁有更高的优先级,因此一个写锁请求可能会被插入到读锁队列的前面
尽管存储引擎可以管理自己的锁,mysql本身还是会使用各种有效的表锁来实现不同的目的。例如,服务器会为诸如alter table之类的语句使用表锁,而忽略存储引擎的锁机制。
锁策略二:行级锁
行级锁可以最大程度地支持并发处理,同时也带来 最大的锁开销。行级锁只在存储引擎层实现,而mysql服务器层没有实现。服务器层完全不了解存储引擎的锁实现。