博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql 死锁案例及分析过程
阅读量:6426 次
发布时间:2019-06-23

本文共 950 字,大约阅读时间需要 3 分钟。

我将分别从以下几个方面进行讲解mysql 死锁 的每一个案例,希望能够对你们有帮忙及启发

  • pre   ---   预备知识(可直接跳过,建议耐着性子看完)

    • 锁类型

    • 一致性非锁定读

    • 一致性锁定读

    • 行锁的三种算法

  • start  ---   正式开始

    • 死锁的条件

    • 死锁分析

    • 死锁示例

 

pre

一、锁类型  innodb存储引擎实现了如下两种标准的行级锁(多粒度锁定之意向锁自行了解,此处抛出而已)

    1. 共享锁(S Lock),允许事务读一行数据。

    2. 排他锁(X Lock),允许事务删除或更新一行数据

    二、一致性非锁定读

  一致性的非锁定读是指InnoDB存储引擎通过行多版本控制(MVCC自行了解)的方式来读取当前执行时间数据库中行的数据,而不需要等待访问的行上X锁的释放。(在InnoDB存储引擎的默认设置下,这是默认的读取方式)

PS:1.该技术不会有额外的开销,因为读取的快照数据其实是行数据之前的版本数据,该实现是通过undo (undo log 事务回滚  自行了解)段来完成。

  2.不同的事务隔离级别下,读取的方式不同(并不是在每个事务隔离级别下都是采用非锁定的一致性读,自行思考,tip:脏读,不可重复读,幻读)

三、一致性锁定读

    1. SELECT...FOR UPDATE 对读取的行记录加一个X锁,其他事务不能对已锁定的行加上任何锁

    2. SELECT...LOCK IN SHARE MODE 对读取的行记录加一个S锁,其他事务可以向被锁定的行加S锁,但如果加X锁,则会被阻塞

(PS:以上要想使用必须在事务中,当事务提交了,锁也就释放了)

四、行锁的三种算法

    1. Record Lock: 单个行记录上的锁

    2. Gap Lock: 间隙锁,锁定一个范围,但不包含记录本身

    3. Next-Key Lock: Gap Lock + Record Lock,锁定一个范围,并且锁定记录本身 (可解决 Phantom Problem)

(PS:当查询的索引含有唯一属性时,InnoDB存储引擎会对Next-Key Lock进行优化,将其降级为Record Lock,即锁住索引本身,而不是范围)

比较懒,上图(分享过的图)

 

 

转载于:https://www.cnblogs.com/Shock-W/p/9349705.html

你可能感兴趣的文章
重新认识javascript对象(三)——原型及原型链
查看>>
小学生学“数学”
查看>>
FastDFS蛋疼的集群和负载均衡(十七)之解决LVS+Keepalived遇到的问题
查看>>
深入剖析Redis系列(二) - Redis哨兵模式与高可用集群
查看>>
Android 用于校验集合参数的小封装
查看>>
iOS混合开发库(GICXMLLayout)七、JavaScript篇
查看>>
instrument 调试 无法指出问题代码 解决
查看>>
理解缓存
查看>>
BAT 经典算法笔试题 —— 磁盘多路归并排序
查看>>
Nginx限制带宽
查看>>
All Web Application Attack Techniques
查看>>
归档日志ORA-19809: 超出了恢复文件数的限制
查看>>
精品德国软件 UltraShredder 文件粉碎机
查看>>
PANDAS 数据合并与重塑(join/merge篇)
查看>>
文件时间信息在测试中的应用
查看>>
直播疑难杂症排查(8)— 播放杂音、噪音、回声问题
查看>>
如何写gdb命令脚本
查看>>
Android ListView展示不同的布局
查看>>
iOS宏(自己使用,持续更新)
查看>>
手把手玩转win8开发系列课程(3)
查看>>