一 简介: MDL锁

二 具体

1 MDL锁
   1 增删查改 申请MDL读锁
   2 ddl语句
      1. 拿MDL写锁
      2. 降级成MDL读锁
      3. 真正做DDL
      4. 升级成MDL写锁
      5. 释放MDL锁

三 问题
1 为什么同一张表的多个DDL不能并行执行
   解答:1 MDL读锁是互相兼容的,可以有多个增删查改
2 MDL写锁是互斥的,只能有一个表的DDL
  问题2 为什么有时候DDL会卡住
   解答:1 MDL读写锁之间是互斥的,所以如果DDL卡住,就证明有事务在执行,不能申请MDL写锁
3 常见卡住的场景 
   1 非常频繁的业务高峰期
   2 有慢查询把持着MDL读锁
4 为什么需要MDL锁
   解答:当事务本身执行的时候理论上是不能容忍表结构在中途发生改变的

05-11 15:34