| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 大数据 -> 死锁场景之insert语句加锁流程分析(二) -> 正文阅读 |
|
[大数据]死锁场景之insert语句加锁流程分析(二) |
死锁场景之insert语句加锁分析(二)关于mysql有哪些锁?锁的分类有哪些?可查看另外一篇博客:mysql 的锁 在实际情景中的加锁情况分析博客请查看另外一篇博客:数据库操作加锁情况分析 关于数据库的死锁日志如何查看? 请查看另外一篇博客:死锁日志查看 关于数据库的insert导致死锁案例查看:死锁场景之insert语句死锁分析 这篇主要是介绍平时常见的insert语句的加锁情况。 大部分的DBA同行都知道在事务执行insert的时候会申请一把插入意向锁(Insert Intention Lock)。在多个会话并发写入不同数据记录至同一索引间隙的时候,并不需要等待其他事务完成,不会发生锁等待。但是如果加入意向锁、next-key锁的时候,再insert的时候的加锁情况进行分析。 情况一:非唯一索引下的insert加锁情况分析1、环境介绍针对mysql数据库,innodb 引擎下,隔离级别在 REPEATABLE READ insert语句加锁情况
说明:创建一个表 my ,id为自增主键索引,num1上有一个普通非唯一索引 2 、事务操作介绍
说明: 事务T2:
事务T1:
3 、死锁日志数据库查看最近的死锁日志:
日志:
加锁情况分析: a. 事务T2 也即sess1执行的事务 sess1 先执行 sql select * from my where num1=5 for update; 该事务持有索引num1=5 的行锁lock_mode X (next key锁),因为是RR隔离级别, 所以sess1 不仅对该记录持有一个行锁,还持有两个gap锁**[3,4]-[5,8], [5,8]-[7,9]** 。 b. 事务T1的日志也即sess2执行的事务 其执行 insert into my(num1,num2) values(4,10); 申请对 num1=4 加锁,根据日志看,其需要加入插入意向锁 但是因为sess1中加上了间隙锁还没释放,故sess2的事务T1等待sess1的事务T2释放锁资源。 情况二:唯一索引下的insert 加锁情况分析1、环境介绍针对mysql数据库,innodb 引擎下,隔离级别在 REPEATABLE READ 出现的死锁问题
说明:创建一个表 my2 ,id为自增主键索引,num1上有一个唯一索引 2 、事务操作介绍
说明: 事务T2:
事务T1:
3 、死锁日志数据库查看最近的死锁日志:
日志:
加锁情况分析: a. 事务T2 也即sess1执行的事务 sess1 先执行 sql select * from my where num1>=5 for update; 该事务持有索引num1=5 的行锁lock_mode X (next key锁),因为是RR隔离级别, 所以sess1 不仅对该记录持有一个行锁,还持有两个gap锁**[2,3]-[5,5], [5,5]-[+∞,+∞]** 。 b. 事务T1的日志也即sess2执行的事务 其执行 insert into my(num1,num2) values(4,10); 申请对 num1=4 加锁,根据日志看,其需要加入插入意向锁 但是因为sess1中加上了next-key锁还没释放,故sess2的事务T1等待sess1的事务T2释放锁资源。 还有一种情况,就是sess1查询一条已经存在的记录,然后对该记录进行删除,暂不提交事务。那么sess2这时候再提交insert这条记录的时候,也会出现等待。这时候insert申请的是一个S共享锁,与delete申请到的nextkey锁冲突,导致了等待的发生。具体案例可查看 死锁场景之insert语句死锁分析 总结本文介绍了两个情况,在RR事务隔离级别下,普通索引与唯一索引两种情况下insert语句的加锁情况。 insert N的流程(非唯一索引的情况):
insert N的流程(有唯一索引的情况):
|
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/24 12:45:19- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |