初识MDL锁

简介: 初识MDL锁

       MDL全称为 meta data lock,中文称作元数据锁,这是从MySQL5.5 开始引入的锁,MDL是为了解决DDL操作和DML操作之间的一致性。从锁的作用范围上来说,MDL算是一种表级锁,是一个server层的锁。

       出现场景:当我们通过alter 语句更新一张表的时候,同时又针对这张表执行了查询语句,假设两者同时执行,那么将来查询到的结果可能就不是我们想要的结果,也就是数据的一致性出了问题。

       为了解决这个问题,从MySQL5.5 开始推出了MDL。

       MDL加锁过程是系统自动控制,无法直接干预,也不需要直接干预,当我们对一个表做增删改查操作的时候,会自动加MDL读锁。当我们要更新表结构的时候,加MDL写锁。加读锁则所有线程可正常读表的元数据,并且读锁不影响表的增删改查操作,只是不能修改表的结构;而加写锁则只拥有锁的线程可以读写元数据,即只有拥有锁的线程才能更新表结构,其他线程不能修改表结构也不能执行相应的增删改查。

online DDL

       MySQL5.6开始引入了online DDL,顾名思义,从名字上就可以看出来是可以在线执行DDL,不和其他操作冲突,具体执行流程如下:

1.DDL(数据库表结构修改)操作需要首先获取MDL写锁。

2.接下来将MDL写锁降级成MDL读锁。

3.做DDL操作,也是最耗时的,但由于此时我们持有的是MDL读锁,因此并不会阻塞其他的增删改查操作。

4.做完DDL操作之后,接下来将MDL读锁升级成MDL写锁。

5.释放MDL锁

注:所有的DDL语句都会导致事务的隐式提交,也就意味着带有DDL语句的事务将来没有办法回滚。

相关文章
|
1月前
|
存储 关系型数据库 MySQL
MySQL数据库锁:共享锁和独占锁
本文详细介绍了`InnoDB`存储引擎中的两种行级别锁:共享锁(S锁)与排他锁(X锁)。通过具体示例展示了这两种锁的工作机制及其在`InnoDB`与`MyISAM`引擎中的表现差异。文章还提供了锁的兼容性矩阵,帮助读者更好地理解锁之间的互斥关系。最后总结了两种锁的特点及适用场景。适合希望深入了解`MySQL`并发控制机制的读者阅读。
47 1
|
3月前
|
SQL 关系型数据库 MySQL
MySQL使用行级锁时,并非直接锁定记录,而是锁定涉及的索引。对于表`user_item`,更新语句先锁定非主键索引`idx_1`,再锁定主键索引。若两条更新语句分别按不同顺序锁定这两个索引,可能导致互相等待对方释放锁,引发死锁。解决方案包括先查询待更新记录的主键,再按主键更新,确保一致的锁定顺序。
43 2
|
3月前
|
SQL 关系型数据库 MySQL
临键锁引发的死锁
【8月更文挑战第4天】
40 0
临键锁引发的死锁
|
5月前
|
SQL 关系型数据库 MySQL
MySQL数据库——锁-行级锁(行锁、间隙锁和临键锁)
MySQL数据库——锁-行级锁(行锁、间隙锁和临键锁)
91 0
|
6月前
|
数据库 数据安全/隐私保护
什么是行级锁和表级锁
什么是行级锁和表级锁
118 0
《锁》有那些?
锁是计算机科学中用于控制对共享资源的访问的一种同步机制。不同种类的锁适用于不同的场景和需求。下面是一些常见的锁的种类及其详细介绍:
72 1
|
存储 算法 安全
辛辛苦苦的劳动成果,如何上把锁?
辛辛苦苦的劳动成果,如何上把锁?
|
数据可视化 Java
lock锁和死锁
lock锁和死锁
共享锁(读锁)和排他锁(写锁)
共享锁(读锁)和排他锁(写锁)
142 0
|
PHP
并发锁(二):共享锁和独占锁
并发锁(二):共享锁和独占锁
216 0
并发锁(二):共享锁和独占锁