《MySQL学习》 全局锁和表锁

一.MySQL锁的分类

二.全局锁

全局锁对整个数据库加锁,可以执行如下命令,整个数据库都将处于只读状态。

Flush tables with read lock ;

我们可以执行 unlock table进行解锁

unlock table ;

全局锁的典型使用场景 -- 全库逻辑备份

当执行 命令后,整个库都将处于只读状态,在只读状态下对整个数据库做备份,但这样做是有风险的

Flush tables with read lock ;

  1. 如果在主库上做备份,那么在整个备份期间都不能做更新操作,业务无法进行。
  2. 如果在从库上做备份,那么从库将不能执行从主库同步更新过来的binlog日志,导致主从延迟

虽然加全局锁有风险,但是如果不在全局锁,因为不同表之间的执行顺序不同进而备份的时间不同。如果某个表在这个时间差中进行了更新并且成功被备份,而与其有关联的表已经在之前备份完毕已无法更新。此时就发生备份库与被备份库数据不一致。

三.表级锁

MySQL在表级别的锁有两种,分别是表锁与元数据锁(Meta data lock MDL)

表锁

表锁的语法是 lock tables … read/write。与 FTWRL 类似,可以用 unlock tables 主动释放锁,也可以在客户端断开的时候自动释放。需要注意,lock tables 语法除了会限制别的线程的读写外,也限定了本线程接下来的操作对象。

元数据锁

元数据锁 不需要显式使用,在访问一个表的时候会被自动加上。MDL 的作用是,保证读写的正确性。

元数据锁是server层的锁,表级锁,主要用于隔离DML(Data Manipulation Language,数据操纵语言,如select)和DDL(Data Definition Language,数据定义语言,如改表头新增一列)操作之间的干扰。每执行一条DML、DDL语句时都会申请MDL锁,DML操作需要MDL读锁,DDL操作需要MDL写锁(MDL加锁过程是系统自动控制,无法直接干预,读读共享,读写互斥,写写互斥)

全部评论
m了,感谢分享
点赞 回复 分享
发布于 2023-02-16 17:33 云南
学习一下,谢谢分享
点赞 回复 分享
发布于 2023-02-16 17:42 四川

相关推荐

点赞 评论 收藏
分享
德科信息 华为OD岗位 20K+ 统招本科
点赞 评论 收藏
分享
嗷佛快来快来快快快来:我当时就是听了别人的谣言,环境的大变,左右摇摆不定,到最后一事无成。我也给你提不了什么有效的建议,因为我自己就是败犬。但是我确实是从cpp转到了Java,cpp也做过项目,了解过具体的细分方向。如果你感兴趣,不会拦你。因为只要一件事情能坚持下去 就会发光
点赞 评论 收藏
分享
评论
1
3
分享
牛客网
牛客企业服务