MySQL InnoDB Lock Modes

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 行锁的S锁和X锁 Innodb实施标准的行级锁,其中有两种类型的锁:Shared lock即共享锁,S锁。如果事务对数据行r持有S锁,那么允许其它事务对数据行r持有S锁,但不允许其它事务对数据行持有X锁。

行锁的S锁和X锁

Innodb实施标准的行级锁,其中有两种类型的锁:
Shared lock即共享锁,S锁。如果事务对数据行r持有S锁,那么允许其它事务对数据行r持有S锁,但不允许其它事务对数据行持有X锁。
Exclusive lock即排它锁,X锁。如果事务T1对数据行r持有X锁,那么就不允许其它事务对数据行持有S锁或X锁,除非等到T1释放r上的X锁

意向锁(Intention lock)

Innodb支持多粒度锁,即允许记录锁(record locks)和表锁共存(InnoDB supports multiple granularity locking which permits coexistence of record locks and locks on entire tables)。为了在多个粒度级别上实现锁定,innodb引进了意向锁。有两种意向锁:
Intention shared(IS):意向共享锁,表示事务T将要对表中数据行加S锁,而先在表级别上加的就是IS锁;
Intention exclusive(IX):意向排它锁,表示事务T将要对表中数据行加X锁,而先在表级别上加的就是IX锁;

意图锁是表锁,它指示事务稍后将在表数据行上加何种类型的锁。IS锁表示事务稍后会在数据行上加S锁,IX锁表示事务稍后会在数据行上加X锁。常见的,像“select … lock in share mode”语句会加IS锁,“select … for update”语句会加IX锁。

所以,引入意图锁的目的就是为了支持多粒度锁定,并能通过意图锁显示事务锁定了表中的某些行,或者将要锁定表中的某些行。

意图锁的协议如下:
一个事务要想获得行上的S锁,必须先获取该表上的IS或者更强的锁;
一个事务要想获得行上的X锁,必须先获取该表上的IX锁。

四种锁之间的兼容性如下:
_1

如果事务请求的锁与现有锁兼容,则授予该事务锁;但如果与现有锁冲突,则不授予该事务锁,事务需要等待现有锁被释放后才能获取锁。

说明:
个人认为,上面的S和X锁是表级别的S和X锁。但之前和朋友讨论,说没有表级别的S和X锁,只有行级别的S和X锁,并上面指的是行级别的S和X锁。后来发现在姜承尧的innodb内幕这本书中,也提到上面指的是行级别的S和X锁。
因此有些疑惑的就是:锁的粒度不同,如何讨论兼容性?更何况意图锁引入的目的就是为了支持mysql的多粒度锁定。

死锁

死锁演示:
会话1上开启事务T1:

mysql> start transaction;
mysql> select * from ecs_payment where pay_id=2332 lock in share mode;
+--------+----------+----------+---------+----------+-----------+------------+---------+--------+-----------+
| pay_id | pay_code | pay_name | pay_fee | pay_desc | pay_order | pay_config | enabled | is_cod | is_online |
+--------+----------+----------+---------+----------+-----------+------------+---------+--------+-----------+
|   2332 | 83       | ^{}      | 4090.99 | bwlw]^k  |        13 | lb^wkw]    |       1 |      0 |         0 |
+--------+----------+----------+---------+----------+-----------+------------+---------+--------+-----------+
AI 代码解读

会话2上开启事务T2:

mysql> start transaction;
Query OK, 0 rows affected (0.00 sec)
mysql> update ecs_payment set pay_name='tiatiao' where pay_id=2332;    --被卡住
AI 代码解读

会话1的事务T1再执行操作:

mysql> delete from ecs_payment where pay_id=2332;
Query OK, 1 row affected (0.00 sec)
AI 代码解读

这时再看会话2的事务T2,会输出如下信息:

ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transaction
AI 代码解读

发生死锁的四个必要条件:
互斥条件
不可剥夺
请求与保持
循环等待

注意:
如果InnoDB监视器输出的最新检测到的死锁部分包含如下输出信息:

TOO DEEP OR LONG SEARCH IN THE LOCK TABLE WAITS-FOR GRAPH, WE WILL ROLL BACK FOLLOWING TRANSACTION
AI 代码解读

这表明锁等待列表上的事务数量已经达到了200个的限制,超过200个事务的等待列表被视为死锁,这个数量限制和参数LOCK_MAX_DEPTH_IN_DEADLOCK_CHECK有关

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
0
0
2
32412
分享
相关文章
MySQL8.4创建keyring给InnoDB表进行静态数据加密
MySQL8.4创建keyring给InnoDB表进行静态数据加密
66 1
使用温InnoDB缓冲池启动MySQL测试
使用温InnoDB缓冲池启动MySQL测试
41 0
MySQL底层概述—10.InnoDB锁机制
本文介绍了:锁概述、锁分类、全局锁实战、表级锁(偏读)实战、行级锁升级表级锁实战、间隙锁实战、临键锁实战、幻读演示和解决、行级锁(偏写)优化建议、乐观锁实战、行锁原理分析、死锁与解决方案
203 24
MySQL底层概述—10.InnoDB锁机制
MySQL底层概述—5.InnoDB参数优化
本文介绍了MySQL数据库中与内存、日志和IO线程相关的参数优化,旨在提升数据库性能。主要内容包括: 1. 内存相关参数优化:缓冲池内存大小配置、配置多个Buffer Pool实例、Chunk大小配置、InnoDB缓存性能评估、Page管理相关参数、Change Buffer相关参数优化。 2. 日志相关参数优化:日志缓冲区配置、日志文件参数优化。 3. IO线程相关参数优化: 查询缓存参数、脏页刷盘参数、LRU链表参数、脏页刷盘相关参数。
154 12
MySQL底层概述—5.InnoDB参数优化
MySQL底层概述—4.InnoDB数据文件
本文介绍了InnoDB表空间文件结构及其组成部分,包括表空间、段、区、页和行。表空间是最高逻辑层,包含多个段;段由若干个区组成,每个区包含64个连续的页,页用于存储多条行记录。文章还详细解析了Page结构,分为通用部分(文件头与文件尾)、数据记录部分和页目录部分。此外,文中探讨了行记录格式,包括四种行格式(Redundant、Compact、Dynamic和Compressed),重点介绍了Compact行记录格式及其溢出机制。最后,文章解释了不同行格式的特点及应用场景,帮助理解InnoDB存储引擎的工作原理。
MySQL底层概述—4.InnoDB数据文件
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
大数据新视界 --面向数据分析师的大数据大厂之 MySQL 基础秘籍:轻松创建数据库与表,踏入大数据殿堂
本文详细介绍了在 MySQL 中创建数据库和表的方法。包括安装 MySQL、用命令行和图形化工具创建数据库、选择数据库、创建表(含数据类型介绍与选择建议、案例分析、最佳实践与注意事项)以及查看数据库和表的内容。文章专业、严谨且具可操作性,对数据管理有实际帮助。
大数据新视界 --面向数据分析师的大数据大厂之 MySQL 基础秘籍:轻松创建数据库与表,踏入大数据殿堂
docker拉取MySQL后数据库连接失败解决方案
通过以上方法,可以解决Docker中拉取MySQL镜像后数据库连接失败的常见问题。关键步骤包括确保容器正确启动、配置正确的环境变量、合理设置网络和权限,以及检查主机防火墙设置等。通过逐步排查,可以快速定位并解决连接问题,确保MySQL服务的正常使用。
450 82
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL集群架构负载均衡故障排除与解决方案
本文深入探讨 MySQL 集群架构负载均衡的常见故障及排除方法。涵盖请求分配不均、节点无法响应、负载均衡器故障等现象,介绍多种负载均衡算法及故障排除步骤,包括检查负载均衡器状态、调整算法、诊断修复节点故障等。还阐述了预防措施与确保系统稳定性的方法,如定期监控维护、备份恢复策略、团队协作与知识管理等。为确保 MySQL 数据库系统高可用性提供全面指导。

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等