MySQL innoDB 中的锁升级

Posted Amy-Y

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL innoDB 中的锁升级相关的知识,希望对你有一定的参考价值。

什么是锁升级?

  • 锁升级是指将当前锁的粒度降低,如一把行锁升级唯一把页锁,或者将页锁升级为表锁,如果在数据库设计中认为锁是一中稀有资源,哪么就会频繁有锁升级的现象

发生锁升级的现象

  • 当一条SQL语句对一个对象上持有的锁数量超锁了阈值,默认这个阈值为5000,但是对于不同对象不会发生锁升级
  • 锁资源占用的内存超过激活内存的百分之40 就会发生锁升级

但是!!!!!

innoDB 引擎不存在锁升级的问题,因为其不是根据每个记录来产生啊行锁的,是根据每个事务访问的每个页对锁进行管理的。

其实吧,这个根据页进行加锁我没搞懂,X,S锁作何解释,难道不是当一条SQL语句加的锁范围大了 在next-keys-locks 的加锁算法下导致全页被锁住 或全表被锁住。 我感觉这玩意也是锁升级啊。 要是哪位大神看到帮我指点指点

以上是关于MySQL innoDB 中的锁升级的主要内容,如果未能解决你的问题,请参考以下文章

MySql-InnoDB存储引擎的锁和事务

MySql-InnoDB存储引擎的锁和事务

Innodb中的锁

MySQL Innodb 中的锁

MySQL中的锁

MySQL_InnoDB的锁和事务模型