MySQL读书笔记-并发控制

MySQL在两个层面的并发控制。

  • 服务器层
  • 存储引擎层

无论何时,只要有多个查询需要在同一时刻修改数据,都会产生并发控制的问题。MySQL是如何控制并发读写的呢?在处理并发读或者写时,可以通过实现一个由两种类型的锁组成的锁系统来解决问题。这两种类型的锁,通常被称为共享锁(shared lock)和排他锁(exclusive lock),或者读锁(read lock)和写锁(write lock)。数据库每时每刻都在发生锁定,当某个用户在修改某一部分数据时,MySQL会通过锁定防止其他用户读取同一个数据。

读写锁

读锁,是共享的(互不阻塞的),多个客户在同一时刻可以同时读取同一个资源,而互不干扰。
写锁,是排他的(会阻塞其他的写锁和读锁),这是出于安全策略的考虑。

锁力度

一种提高共享资源并发性的方式就是,让锁定对象更有选择性。尽量只锁定需要修改的部分数据,而不是所有的数据。任何时候,在给定的资源上,锁定的数据量越少,则系统的并发程度越高。

问题是,加锁也需要消耗资源。锁的各种操作,包括,获得锁,检查锁,释放锁等,都会增加系统的开销。锁策略,就是在锁的开销和数据安全性之间寻求平衡。大多数商业数据库都没有提供更多的选择,一般都是在表上施加行级锁(row-level lock)。而MySQL则提供了多种选择,每种MySQL存储引擎都可以实现自己的锁策略和锁粒度。下面是两种重要的锁策略。

  • 表锁(table lock)

是开销最小的锁策略。在特定的场景中,表锁也可能有良好的性能。

  • 行级锁(row lock)

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值