怎么解决Mysql自增锁问题?

作者: 从梦流风 | 来源:发表于2018-07-07 10:43 被阅读1次

最近在学习群里答疑的时候,常会有同学问我:在做基准测试时候,批量插入数据时,有很多自增锁等待,我告诉他解决办法:

  • 1.innodb_autoinc_lock_mode=2

  • 2.innodb_autoextend_increment参数再增大

再停止测试不再有自增锁等候了。

下面给大家说下为何??

处理此问题的关键点是innodb_autoinc_lock_mode =2。

我们来看看innodb_autoinc_lock_mode 这个参数干什麼的?

此参数可取的值有三个:0、1、2严谨水平逐步递加,功能逐步增加。

  • 0:传统方式。串行自增的,并且是连续的。这样需要独占的串行锁,语句完成才释放锁,所以性能最低。例如:1、2、3、4、5、6

  • 1:连续方式。自增的,并且是连续的。当语句申请到自增锁就释放自增锁,自增锁就可以给其它语句使用。性能会好很多。这个是系统默认的。例如:1、2、3、4、5、6

  • 2:交错方式。多语句插入数据时,有可能自增的序列号和执行先后顺不一致,并且中间可能有断裂。一次分配一批自增值,然后下个语句就再进行分配一批自增值,阻塞很小,性能很高。例如:1、2、3、6、5

运用2状况,需求留意本人使用能否需求延续的自增值,假如需求,就不要运用。

如果还有什么疑问或者想要了解怎么入门编程,可以通过下面的传送门找到柳猫,据说聪明的人都能看到~

相关文章

  • 怎么解决Mysql自增锁问题?

    最近在学习群里答疑的时候,常会有同学问我:在做基准测试时候,批量插入数据时,有很多自增锁等待,我告诉他解决办法: ...

  • MySQL InnoDB锁类型

    1)自增锁(AUTO-INC Locks),表级锁用于AUTO_INCREMENT的自增主键,MySQL 8.0....

  • PostgreSQL中自增列和自增ID的正确打开方式

    MySQL转到PG后很多小伙伴遇到的问题就是PostgreSQL中的主键ID自增问题(其他解决方式很多这里就不关注...

  • 关于 mysql 事务中的自增 id 的疑问

    mysql 的自增id 在事务回滚后会怎么样? mysql 的自增id 是什么时候生成id的? 开始一个试验: 创...

  • Innodb-Insert-锁

    锁类型 元数据锁 表锁 IX 自增锁 自增锁模式通过参数innodb_autoinc_lock_mode来控制,加...

  • 分布式主键

    mysql 自增id 自增id 缺点 :1 mysql insert 后 必须 SELECT LAST_INSE...

  • MySQL 间隙锁

    间隙锁 间隙锁在MySQL中解决了幻读问题,在MySQL中通过RR也能解决幻读。 但是使用间隙锁时有两个坑需要注意...

  • 数据库_锁

    六、数据库锁1.mysql都有什么锁,死锁判定原理和具体场景,死锁怎么解决?MySQL有三种锁的级别:页级、表级、...

  • Mysql的锁和自增主键

    Mysql中的常用命令 Mysql的自增主键 Mysql中维护这个自增主键的值是存放在内存中的,这一点就很关键,也...

  • mysql操作数据库

    MYSQL主键自增用法

网友评论

本文标题:怎么解决Mysql自增锁问题?

本文链接:https://www.haomeiwen.com/subject/dkziuftx.html