mysql自增主键的锁问题

论坛 期权论坛 脚本     
匿名技术用户   2021-1-2 20:04   74   0

每个带有自增属性的表都有一个隐式计数器来维护自增ID到了什么值。在插入的时侯通过加表锁来更新这个计数器。插入完成后就释放,并不是等到事务结束。但是这严重影响了程序的并发性,尤其是在执行insert .... select的时候会阻塞其他事务的插入。

所以mysql 5.1.22进行了优化,对于确定数量的插入simple inserts通过互斥量来做到的。

MySQL 5.1.22开始,InnoDB提供了一种轻量级互斥的自增实现机制,在内存中会有一个互斥量(mutex),每次分配自增长ID时,就通过估算插入的数量(前提是必须能够估算到插入的数量,否则还是使用传统模式),然后更新mutex,下一个线程过来时从新 mutex 开始继续计算,这样就能避免传统模式非要等待每个都插入之后才能获取下一个,把“锁”降级到 只在分配id的时候 锁定互斥量。

参考资料:

https://zhuanlan.zhihu.com/p/84046604

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:7942463
帖子:1588486
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP