返回顶部
首页 > 资讯 > 数据库 >MySQL自增锁模式innodb_autoinc_lock_mode参数详解
  • 425
分享到

MySQL自增锁模式innodb_autoinc_lock_mode参数详解

2024-04-02 19:04:59 425人浏览 薄情痞子
摘要

innodb_autoinc_lock_mode这个参数控制着在向有auto_increment 列的表插入数据时,相关锁的行为; 通过对它的设置可以达到性能与安全(主从的数据一致性)的平衡 【0】我

innodb_autoinc_lock_mode这个参数控制着在向有auto_increment 列的表插入数据时,相关的行为;


通过对它的设置可以达到性能与安全(主从的数据一致性)的平衡

【0】我们先对insert做一下分类


  首先insert大致上可以分成三类:
     1、simple insert 如insert into t(name) values('test')
    2、bulk insert 如load data | insert into ... select .... from ....
    3、mixed insert 如insert into t(id,name) values(1,'a'),(null,'b'),(5,'c');



【1】innodb_autoinc_lock_mode 的说明


  innodb_auto_lockmode有三个取值:
     1、0 这个表示tradition 传统
     2、1 这个表示consecutive 连续
     3、2 这个表示interleaved 交错


【1.1】tradition(innodb_autoinc_lock_mode=0) 模式:


   1、它提供了一个向后兼容的能力
   2、在这一模式下,所有的insert语句("insert like") 都要在语句开始的时候得到一个
      表级的auto_inc锁,在语句结束的时候才释放这把锁,注意呀,这里说的是语句级而不是事务级的,一个事务可能包涵有一个或多个语句。
   3、它能保证值分配的可预见性,与连续性,可重复性,这个也就保证了insert语句在复制到slave
            的时候还能生成和master那边一样的值(它保证了基于语句复制的安全)。
       4、由于在这种模式下auto_inc锁一直要保持到语句的结束,所以这个就影响到了并发的插入。


【1.2】consecutive(innodb_autoinc_lock_mode=1) 模式:

  1、这一模式下去simple insert 做了优化,由于simple insert一次性插入值的个数可以立马得到
          确定,所以Mysql可以一次生成几个连续的值,用于这个insert语句;总的来说这个对复制也是安全的
          (它保证了基于语句复制的安全)
  2、这一模式也是mysql的默认模式,这个模式的好处是auto_inc锁不要一直保持到语句的结束,只要
          语句得到了相应的值后就可以提前释放锁


【1.3】interleaved(innodb_autoinc_lock_mode=2) 模式
   1、由于这个模式下已经没有了auto_inc锁,所以这个模式下的性能是最好的;但是它也有一个问题,就是
          对于同一个语句来说它所得到的auto_increment值可能不是连续的。

【2】如果你的二进制文件格式是mixed | row 那么这三个值中的任何一个对于你来说都是复制安全的。
   由于现在mysql已经推荐把二进制的格式设置成row,所以在binlog_fORMat不是statement的情况下最好是innodb_autoinc_lock_mode=2 这样可能知道更好的性能。

三种模式简要说明:
0:traditonal (每次都会产生表锁)
1:consecutive (会产生一个轻量锁,simple insert会获得批量的锁,保证连续插入)
2:interleaved (不会锁表,来一个处理一个,并发最高)


总结
1 innodb  row复制时,可将innodb_autoinc_lock_mode设置为2,这时可在所有insert情况下表获得最大并发度
2 innodb statement复制时,可将innodb_autoinc_lock_mode设置为1,保证复制安全的同时,获得简单insert语句的最大并发度
3 myisam引擎情况下,无论什么样自增id锁都是表级锁,设置innodb_autoinc_lock_mode参数无效(测试略)
4 实际上提问者说到的在innodb引擎下自增id值作为主键的情况下,相比uuid或者自定义的主键,是可以提到插入速度的,因为innodb是主键聚集索引,实际的主键值必须按照主键顺序存取,那么自增id本身就是升序的,那么在插入数据时,底层就不必再做额外的排序操作,也减少了索引页分裂的次数,从而大大增加insert速度(除非其他方案也能保证主键完全自增)
  



修改自增锁级别方法:
编辑/etc/my.cnf,加入如下行:
innodb_autoinc_lock_mode=2


直接通过命令修改会报错:
mysql(mdba@localhost:(none) 09:32:19)>set global innodb_autoinc_lock_mode=2;
ERROR 1238 (HY000): Variable 'innodb_autoinc_lock_mode' is a read only variable


您可能感兴趣的文档:

--结束END--

本文标题: MySQL自增锁模式innodb_autoinc_lock_mode参数详解

本文链接: https://lsjlt.com/news/46315.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySQL自增锁模式innodb_autoinc_lock_mode参数详解
    innodb_autoinc_lock_mode这个参数控制着在向有auto_increment 列的表插入数据时,相关锁的行为; 通过对它的设置可以达到性能与安全(主从的数据一致性)的平衡 【0】我...
    99+
    2024-04-02
  • mysql存储过程IN,OUT,INOUT参数模式使用详解
    IN模式 : 参数输入模式   OUT模式 : 参数输出模式   INOUT模式 : 作为输入和输出模式 区别: in类型:内部运算变化不影响外部; out类型:内部运算变化影响外部变化并且传参到储存过程时默认初始化参数...
    99+
    2017-09-18
    mysql存储过程IN OUT INOUT参数模式使用详解
  • MySQL8.0新增配置参数详解
    MySQL8.0新增或改进了数据字典、原子DDL、安全和账户、资源管理、InnoDB增强、字符集支持、JSON增强、字段类型支持、优化器、通用表达式、窗口函数、正则表达式支持、内部临时表、日志、备份锁等特性...
    99+
    2024-04-02
  • MySQL 5.7 自增字段相关参数说明
    auto_increment_increment 和 auto_increment_offset参数用在主主复制中,用于控制AUTO_INCREMENT字段的操作,在不同节点使用不同的生成规则,以避免生成的...
    99+
    2024-04-02
  • 详解MySQL自增主键的实现
    目录一、自增值保存在哪儿?二、自增值修改机制三、自增值的修改时机四、自增锁的优化五、自增主键用完了一、自增值保存在哪儿? 不同的引擎对于自增值的保存策略不同 1.MyISAM引擎的自...
    99+
    2024-04-02
  • 在MySQL中自定义参数的使用详解
    MySQL变量包括系统变量和系统变量。这次的学习任务是用户自定义变量。用户变量主要包括局部变量和会话变量。 用户自定义变量的声明方法形如:@var_name,其中变量名称由字母、数字、“.”、“_”和“$”...
    99+
    2024-04-02
  • Vue参数的增删改实例详解
    目录展示参数明细展示参数明细功能实现删除参数明细功能实现静态属性的更新总结展示参数明细 elementui Tag标签 <el-table-column label="明细...
    99+
    2024-04-02
  • Mysql数据库自增id、uuid与雪花id详解
    目录概念介绍三种主键聚簇索引与非聚簇索引自增iduuid雪花id与应用总结概念介绍 三种主键 自增id :1 2 3 4 5…… uuid :UUID是Universally Unique I...
    99+
    2023-02-28
    mysql自增id和uuid 数据库union的用法 mysql自增主键
  • SeataAT模式如何实现行锁详解
    目录前言如何加锁为什么是行锁前言 我们在很多博客中都有发现,Seata AT模式里面的全局锁其实是行锁,这也是Seata AT模式和XA模式在锁粒度上的最大区别。我们可以在官网看到这...
    99+
    2022-11-13
    Seata AT模式实现行锁 Seata AT 行锁
  • Mysql explain 各参数详解
    id序号 select_type simple:即简单select 查询,不包含union及子查询; primary:最外层的 select 查询; union:表示此查询是 union 的第二或随后的查...
    99+
    2016-04-15
    Mysql explain 各参数详解
  • c++类函数作为模板参数实现方式详解
    目录需求背景实现方式struct + operatorPass Function Signature需求背景 DB操作有四种基本操作:Insert、Update、Delete和Que...
    99+
    2023-03-01
    c++ 类函数作为模板参数 c++ 类函数
  • Java增加自定义注解进行校验入参详解
    目录背景接下来,Show Time注解类注解的Aspect类controller背景 客户使用我们系统的时候,查询不带任何查询条件,查询就返回全部数据,500多万条数据啊,然后直接导...
    99+
    2023-05-15
    Java自定义注解校验入参 Java自定义注解 Java校验入参
  • Python详解argparse参数模块之命令行参数
    目录前言示例一:最简参数对象示例二:整数求和示例三:文件是否被篡改自定义类型choices选项限定required必选参数子命令前言 help(argparse)查看说明文档,&ld...
    99+
    2024-04-02
  • MySQL InnoDB常见参数详解
    一、文件(数据文件、日志文件)      1、相关参数:           innodb_data_home_dir &nb...
    99+
    2024-04-02
  • Mysql /etc/my.cnf参数详解(二)
    #buffer相关 #buffer pool根据实际内存大小调整,标准为物理内存的50% innodb_buffer_pool_size=15996M //默认值128M,innodb_buffer_pool_size | 13421772...
    99+
    2023-09-03
    mysql adb android
  • Nest.js参数校验和自定义返回数据格式详解
    0x0 参数校验 参数校验大部分业务是使用 Nest.js 中的管道 方法实现,具体可以查阅文档 。不过编写过程中遇到一些问题,虽然文档讲得比较晦涩。 在做个查询接口,里面包含一些...
    99+
    2024-04-02
  • 详解spring注解式参数校验
    一般入参我们都会转为vo对象。那么直接在对象的属性上注解即可。 其实spring用的是hibernate的validator.步骤配置spring.xml<mvc:annotation-driven />...
    99+
    2023-05-31
    spring 校验 注解
  • Java参数传递方式详解
    Java中参数传递的方式是什么样的呢?是值传递还是引用传递呢? 答案是值传递。 为什么呢? 先来了解一些基础。。。。。 1. 形参&实参 形参:传递给函数/方法的参数,有确定的值 实参:定义函数...
    99+
    2023-09-16
    java 开发语言
  • MySQL query_cache_type 参数与使用详解
    MySQL设置查询缓存的用意:   把查询到的结果缓存起来,下次再执行相同查询时就可以直接从结果集中取;这样就比重新查一遍要快的多。 查询缓存的最终结果是事与愿违:   之所以查询缓存并没有能起到提升性能的做用,客观...
    99+
    2022-05-25
    MySQL query_cache_type
  • MYSQL配置参数优化详解
    MySQL参数优化对于不同的网站,及其在线量,访问量,帖子数量,网络情况,以及机器硬件配置都有关系,优化不可能一次性完成,需要不断的观察以及调试,才有可能得到最佳的效果。 1)连接请求的变量 1、max_...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作