丁奇的MySQL基础课
林晓斌(网名“丁奇”)
前阿里资深技术专家
立即订阅
4 人已学习
课程目录
已完结 6 讲
01 | 基础架构:一条SQL查询语句是如何执行的?
免费
02 | 日志系统:一条SQL更新语句是如何执行的?
03 | 事务隔离:为什么你改了我还看不见?
04 | 深入浅出索引(上)
05 | 深入浅出索引(下)
06 | 全局锁和表锁 :给表加个字段怎么有这么多阻碍?
丁奇的MySQL基础课
登录|注册

06 | 全局锁和表锁 :给表加个字段怎么有这么多阻碍?

林晓斌 2019-08-09
今天我要跟你聊聊 MySQL 的锁。数据库锁设计的初衷是处理并发问题。作为多用户共享的资源,当出现并发访问的时候,数据库需要合理地控制资源的访问规则。而锁就是用来实现这些访问规则的重要数据结构。
根据加锁的范围,MySQL 里面的锁大致可以分成全局锁、表级锁和行锁三类。今天这篇文章,我会和你分享全局锁和表级锁。而关于行锁的内容,我会留着在下一篇文章中再和你详细介绍。
这里需要说明的是,锁的设计比较复杂,这两篇文章不会涉及锁的具体实现细节,主要介绍的是碰到锁时的现象和其背后的原理。

全局锁

顾名思义,全局锁就是对整个数据库实例加锁。MySQL 提供了一个加全局读锁的方法,命令是 Flush tables with read lock (FTWRL)。当你需要让整个库处于只读状态的时候,可以使用这个命令,之后其他线程的以下语句会被阻塞:数据更新语句(数据的增删改)、数据定义语句(包括建表、修改表结构等)和更新类事务的提交语句。
全局锁的典型使用场景是,做全库逻辑备份。也就是把整库每个表都 select 出来存成文本。
以前有一种做法,是通过 FTWRL 确保不会有其他线程对数据库做更新,然后对整个库做备份。注意,在备份过程中整个库完全处于只读状态。
取消
完成
0/1000字
划线
笔记
复制
© 版权归极客邦科技所有,未经许可不得传播售卖。 页面已增加防盗追踪,如有侵权极客邦将依法追究其法律责任。
该试读文章来自付费专栏《丁奇的MySQL基础课》,如需阅读全部文章,
请订阅文章所属专栏。
立即订阅
登录 后留言

精选留言(6)

  • 樂文💤
    写的太好了这几篇MYSQL都,通熟易懂,层层递进,不知老师会不会出PostgreSQL的教程吖?或者有没有PG相关的推荐书籍,现在还挺多公司在用PG的
    2019-08-15
    4
  • 谷鱼
    但是好像对于只增不改的表,myisam引擎查询会很快,不可以使用吗
    2019-08-16
    1
  • 明翼
    老师,你好,问下,MDL锁到底是什么时候加的那?普通的没有加begin开头的select语句会不会加那,看了没理解,谢谢!
    2019-08-13
    1
    1
  • Geek_steven_wang
    读锁之间不互斥,因此你可以有多个线程同时对一张表增删改查。 这句是不是比武,应该是“多个线程同时对一张表查”
    2019-11-23
  • 平淡
    在C值相同的情况下,叶子节点的排序,是受a b值影响的吗?
    2019-09-20
  • Mr_杨
    您好,请教一下,如果是个大的表,更新频繁,加字段,该怎么处理呢?
    2019-08-22
收起评论
6
返回
顶部