什么是锁升级?
- 锁升级是指将当前锁的粒度降低,如一把行锁升级唯一把页锁,或者将页锁升级为表锁,如果在数据库设计中认为锁是一中稀有资源,哪么就会频繁有锁升级的现象
发生锁升级的现象
- 当一条SQL语句对一个对象上持有的锁数量超锁了阈值,默认这个阈值为5000,但是对于不同对象不会发生锁升级
- 锁资源占用的内存超过激活内存的百分之40 就会发生锁升级
但是
!!!!!
innoDB 引擎不存在锁升级的问题,因为其不是根据每个记录来产生啊行锁的,是根据每个事务访问的每个页对锁进行管理的。
其实吧,这个根据页进行加锁我没搞懂,X,S锁作何解释,难道不是当一条SQL语句加的锁范围大了 在next-keys-locks 的加锁算法下导致全页被锁住 或全表被锁住。 我感觉这玩意也是锁升级啊。 要是哪位大神看到帮我指点指点
版权声明:本文为weixin_40413961原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。