mysql自增主键的锁问题

在MySQL 5.1.22版本中,InnoDB引擎引入了轻量级互斥自增实现,通过内存中的互斥量进行ID分配,提高了并发插入性能。此机制允许在分配自增长ID时进行锁定,而非整个插入过程,从而显著提升了插入操作的并发性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

每个带有自增属性的表都有一个隐式计数器来维护自增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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值