MySQL的并发控制

当有多个查询在同一时刻修改同一数据时,便会产生并发问题。MySQL通过锁来进行并发控制。

读写锁

读锁又称共享锁(S锁),读锁互不干扰,多个客户在同一时刻可以同时读取同一个资源。

写锁又称排他锁(X锁),写锁则是排他的,写锁会阻塞其他写锁和读锁,以确保在给定时间里,只有一个用户执行写入,并防止其他用户读取正在写入的同一资源。

锁粒度

锁粒度指的是锁定的数据量的多少。在给定的资源中,锁定的数据量越少,系统的并发程度越高,只要互相不发生冲突即可。

但是锁的操作也是需要消耗资源的,所谓的错策略,就是在锁的开销和数据的安全性之间寻求平衡,这种平衡也会影响性能。

MySQL比较重要的锁策略有表锁跟行锁。

表锁

表锁是MySQL中最基本的所策略,并且是开销最小的策略。它会锁住整张表。

可以用以下语句获取表锁:

LOCK TABLES
    tbl_name [[AS] alias] lock_type
    [, tbl_name [[AS] alias] lock_type] ...

lock_type: {
    READ [LOCAL]
  | [LOW_PRIORITY] WRITE
}

UNLOCK TABLES

当一个用户对表进行写操作(插入、删除、更新等)前,先获取该表的写锁,这会阻塞其他用户对该表的所有读写操作。只有没有写锁时,其他用户才能获取读锁,读锁之间不相互阻塞。写锁比读锁拥有更高的优先级,因此一个写请求可能会被插入到读锁的前面(写锁可以插入到锁队列中读锁的前面,读锁则不能插入到写锁的前面)。

READ [LOCAL] 锁:

  • 持有锁的session可以读取表,但是不能写入。
  • 多个session可以同时获取同一个表的读锁。
  • 其他session可以在不显式获取读锁的情况下读表。
  • 使用LOCAL可以支持某些类型的并发写操作。在session持有读锁的情况下,允许其他session执行不冲突的insert语句(并发插入),但是,READ LOCAL如果要在持有锁的同时使用服务器外部的进程来操作数据库, 则不能使用它。对于InnoDB 表,READ LOCAL跟READ一样。

[LOW_PRIORITY] WRITE 锁:

  • 持有锁的session可以读写表。
  • 只有持有锁的会话才能访问该表。在释放锁之前,没有其他会话可以访问它。
  • 只有一个session可以获得表的写锁,其他session的写锁请求会被阻塞。
  • 该LOW_PRIORITY修饰符无效。

具体请看:https://dev.mysql.com/doc/refman/5.7/en/lock-tables.html

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 一、事务 1、事务四要素:ACID 对于事务,我之前的理解是很粗糙的,不就是为了保证操作的原子性么?一般订单系统或...
    张伟科阅读 5,192评论 0 5
  • 为了充分发挥MySQL的性能并顺利地使用,就必须理解其设计。MySQL的灵活性体现在很多方面。例如,你可以通过配置...
    李文文丶阅读 4,979评论 0 4
  • 我们都知道事务的几种性质,数据库为了维护这些性质,尤其是一致性和隔离性,一般使用加锁这种方式。同时数据库又是个高并...
    CodeKing2017阅读 3,846评论 0 7
  • 1、好多请求都到来,怎么办? 串行执行:单银行窗口,一个一个来 交叉并发执行:仍然是单银行窗口,但是外面的请求可以...
    钟小胖子阅读 1,148评论 0 0
  • 我有时候想要变成一个男生 因为觉得女生有一点恐怖 从初高中的时候 因为是文科班 男女比例1:3 女生多呢 相处之间...
    第七七阅读 1,675评论 0 0

友情链接更多精彩内容