Mysql锁机制与优化实践以及MVCC底层原理剖析

MySQL锁机制与MVCC原理深度剖析

一、锁机制基础概念

锁是协调多进程/线程并发访问资源的机制,用于解决数据库并发访问中的数据一致性问题。

二、锁分类体系

1. 按性能分类

  • 乐观锁:版本号/CAS机制,适合读多写少场景
  • 悲观锁:默认并发会产生冲突,适合写多场景

2. 按操作粒度分类

锁类型 开销 死锁 并发度 适用场景
表锁 最低 整表迁移
页锁 一般 BDB引擎
行锁 最高 高并发OLTP

3. 按操作类型分类

  • 共享锁(S锁)SELECT ... LOCK IN SHARE MODE
  • 排他锁(X锁)SELECT ... FOR UPDATE
  • 意向锁 :表级锁优化机制
    • IS锁:加表共享锁前获取
    • IX锁:加表排他锁前获取

三、InnoDB特殊锁机制

1. 间隙锁(Gap Lock)

  • 作用范围:锁定索引记录间的间隙
  • 解决幻读:防止在RR级别下其他事务在间隙插入数据
  • 示例SELECT * FROM account WHERE id=18 FOR UPDATE会锁定(10,20)区间

2. 临键锁(Next-key Lock)

行锁 + 间隙锁的组合形式

四、锁优化实践

  1. 确保查询走索引,避免行锁升级表锁
  2. 合理设计索引缩小锁定范围
  3. 减少检索条件范围,避免间隙锁
  4. 控制事务大小,加锁操作尽量靠后
  5. 使用合适的事务隔离级别

五、MVCC多版本并发控制

1. 核心机制

  • 通过undo日志版本链实现
  • 关键字段:
    • trx_id:事务ID
    • roll_pointer:回滚指针

2. ReadView可见性规则

情况 trx_id范围 可见性
已提交 < min_id 可见
将来事务 > max_id 不可见
未提交事务 在视图数组中 不可见
已提交事务 不在视图数组中 可见

3. 隔离级别实现差异

  • RR级别:使用事务首次查询时的ReadView
  • RC级别:每次查询重新生成ReadView

六、锁问题排查

sql 复制代码
-- 查看事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_TRX;

-- 查看锁等待(MySQL 8.0+)
SELECT * FROM performance_schema.data_lock_waits;

-- 分析死锁
SHOW ENGINE INNODB STATUS;

七、存储引擎对比

特性 InnoDB MyISAM
事务支持 支持 不支持
锁粒度 行锁 表锁
并发性能
自动加锁 仅写操作加行锁 查询自动加读锁

提示:实际开发中应优先考虑InnoDB引擎,除非有特殊需求

复制代码
该笔记已适配CSDN的Markdown编辑器,包含:
- 多级标题结构
- 表格对比
- 代码块
- 重点内容标记
- 清晰的分类展示
可直接复制到CSDN的Markdown编辑器中使用
相关推荐
rising start5 小时前
二、全面理解MySQL架构
mysql·架构
星星也在雾里6 小时前
PgBouncer 解决 PostgreSQL 连接数超限 + 可视化监控
数据库·postgresql
bqq198610266 小时前
MySQL性能优化
mysql·mysql优化
雨辰AI7 小时前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务
长城20248 小时前
关于MySql的ONLY_FULL_GROUP_BY问题
数据库·mysql·聚合列
常常有8 小时前
MySQL 底层执行原理:输入SQL语句到两阶段提交
数据库·sql·mysql
Mr. zhihao8 小时前
深入解析redis基本数据结构
数据结构·数据库·redis
m0_748839498 小时前
利用天正暖通CAD快速掌握风管数量统计的方法
数据库
随身数智备忘录8 小时前
什么是设备管理体系?设备管理体系包含哪些核心模块?
网络·数据库·人工智能
海市公约9 小时前
MySQL更新语句执行全流程:从Buffer Pool修改到二阶段提交
数据库·mysql·binlog·innodb·undo log·二阶段提交·update执行原理