MySQL innoDB 中的锁升级
Posted Amy-Y
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL innoDB 中的锁升级相关的知识,希望对你有一定的参考价值。
什么是锁升级?
- 锁升级是指将当前锁的粒度降低,如一把行锁升级唯一把页锁,或者将页锁升级为表锁,如果在数据库设计中认为锁是一中稀有资源,哪么就会频繁有锁升级的现象
发生锁升级的现象
- 当一条SQL语句对一个对象上持有的锁数量超锁了阈值,默认这个阈值为5000,但是对于不同对象不会发生锁升级
- 锁资源占用的内存超过激活内存的百分之40 就会发生锁升级
但是!!!!!
innoDB 引擎不存在锁升级的问题,因为其不是根据每个记录来产生啊行锁的,是根据每个事务访问的每个页对锁进行管理的。
其实吧,这个根据页进行加锁我没搞懂,X,S锁作何解释,难道不是当一条SQL语句加的锁范围大了 在next-keys-locks 的加锁算法下导致全页被锁住 或全表被锁住。 我感觉这玩意也是锁升级啊。 要是哪位大神看到帮我指点指点
以上是关于MySQL innoDB 中的锁升级的主要内容,如果未能解决你的问题,请参考以下文章