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