innodb_autoinc_lock_mode 是控制 MySQL 自增 ID 插入时加锁行为的参数,影响并发性能与 ID 连续性;默认值 1 平衡安全与性能,0 已弃用,2 需 ROW 格式 binlog 且跳号不可避免。innodb_autoinc_lock_mode 是什么,为什么改它这个参数控制 MySQL 在插入自增 ID 时的加锁行为,直接影响并发插入性能和 ID 分配的连续性。默认值是 1("连续"模式),但高并发批量插入(比如 INSERT ... SELECT、REPLACE、LOAD DATA)时容易卡住,或出现 ID 跳号------这不是 bug,是设计使然。想让自增 ID 尽量紧凑、减少锁等待?得调它;想吞吐优先、能接受跳号?默认就行。关键是别在没理解场景时盲目设成 0 或 2,否则主从不一致或 binlog 复制失败的风险会立刻浮现。三种取值的实际影响和适用场景0(传统模式):全表级 AUTO_INC 锁,每次插都等,ID 绝对连续,但并发极低。只在老版本兼容或极特殊审计要求下用,现在基本不用。1(默认,连续模式):普通 INSERT 用轻量锁,批量语句(如 INSERT INTO t SELECT ...)仍会预分配一段 ID 并加表锁。平衡了性能和可预测性,主从复制安全(statement-based 和 row-based 都 OK)。2(交错模式):所有插入都不加表锁,ID 分配完全交错,性能最高,但 ID 必然跳号,且 仅支持 row-based binlog 格式。如果 binlog_format 还是 STATEMENT,直接报错 ERROR 1665 (HY000): Cannot execute statement: binlogging impossible。无序列表说明: 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
Nturmoils6 分钟前
一台 2C2G 服务器上的 KingbaseES 安装记录郑洁文38 分钟前
面向Web安全的Python渗透测试系统设计与实现情绪总是阴雨天~1 小时前
智能语音分析Agent项目SelectDB1 小时前
从 Machine-Readable 到 Agent-Ready:面向智能体的数据库接口演进画江湖Test1 小时前
Redis 块的原理流烟默1 小时前
国产数据库CERDB是什么以及服务启停数据库小学妹2 小时前
关系型数据库核心原理拆解:SQL解析、事务引擎、存储结构全链路分析海市公约2 小时前
Redis主从复制全量同步七步时序与命令传播机制详解我是唐青枫2 小时前
Java JdbcTemplate 实战指南:用 Spring 轻量完成数据库增删改查