每个带有自增属性的表都有一个隐式计数器来维护自增ID到了什么值。在插入的时侯通过加表锁来更新这个计数器。插入完成后就释放,并不是等到事务结束。但是这严重影响了程序的并发性,尤其是在执行insert .... select的时候会阻塞其他事务的插入。
所以mysql 5.1.22进行了优化,对于确定数量的插入simple inserts通过互斥量来做到的。
MySQL 5.1.22开始,InnoDB提供了一种轻量级互斥的自增实现机制,在内存中会有一个互斥量(mutex),每次分配自增长ID时,就通过估算插入的数量(前提是必须能够估算到插入的数量,否则还是使用传统模式),然后更新mutex,下一个线程过来时从新 mutex 开始继续计算,这样就能避免传统模式非要等待每个都插入之后才能获取下一个,把“锁”降级到 只在分配id的时候 锁定互斥量。
参考资料:
MySQL自增ID并发优化
在MySQL 5.1.22版本中,InnoDB引擎引入了轻量级互斥自增实现,通过内存中的互斥量进行ID分配,提高了并发插入性能。此机制允许在分配自增长ID时进行锁定,而非整个插入过程,从而显著提升了插入操作的并发性。
1310

被折叠的 条评论
为什么被折叠?



