Innodb锁介绍-Innodb中死锁

栏目: 数据库 · Mysql · 发布时间: 8年前

内容简介:Innodb锁介绍-Innodb中死锁

死锁

当两个以上的运算单元,双方都在等待对方停止运行,以获取系统资源,但是没有一方提前退出时,就称之为死锁。

死锁问题是计算机系统中常见的问题,在Innodb中同样存在。

死锁的产生条件

死锁产生必须要满足以下四个条件:

  1. 互斥条件 : 即为某个资源在同一时间只允许被一个单元占有。
  2. 不可抢占条件 :被单元占有的资源不可被其它单元抢占。
  3. 占有且申请条件 :单元当前至少占有一个资源,且该单元同时向系统申请其它的资源。
  4. 循环等待条件 :单元之前存在一个资源的循环等待序列。

死锁范例

Innodb锁介绍-Innodb中死锁

在百度上盗了一张图,如图所示,单元T1和T2各自占有了一个资源,又同时想要占据别人的资源,这样僵持不下,也就产生了死锁。对于计算机系统而言,死锁会导致系统停滞,对于Innodb而言,死锁会给数据的读写产生阻碍。

Innodb中的死锁

在介绍之前,先讲一个我们工作中踩到的一个坑。

背景描述

我们的订单表中存在一个Unique Key,假设该Unique Key的名字为U_KEY,它是由一个ID和时间戳构成的。在实际运行中,存在用同一个Unique Key反复创建订单的行为,这种情况的发生有可能是因为恶意刷单或者是偶然的请求重发。对于这种情况,最先到达的插入请求会成功,之后的请求会产生Unique Key冲突而失败,但这个过程中会时不时的出现Dead Lock Detected的情况(数据库会自己去Kill死锁的),这里我们采用的是 insert ignore

在插入时,MySQL会给行记录加上排他锁(index-record lock),假如此时有三个同样的插入请求,都开启了事务,其中一个先拿到了排他锁开始插入,之后的事务会出现Duplicate Key错误,而此时它们会申请该行的共享锁,如果这个时候拿到排他锁的事务回滚,那么另外两个事务会同时申请该行的排他锁(过程参考 MySQL锁机制 。由于排他锁和共享锁是互斥的,此时就产生了死锁的情况。

这里可能会有人有疑问,为什么出现Duplicate Key错误的时候会加共享锁了,我的理解是冲突检测本身是一种读操作,所以冲突之后的轮询需要加共享锁。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

内容创业:内容、分发、赢利新模式

内容创业:内容、分发、赢利新模式

张贵泉、张洵瑒 / 电子工业出版社 / 2018-6 / 49

越来越多的内容平台、行业巨头、资本纷纷加入内容分发的战争中,竞争非常激烈。优质的原创性内容将成为行业中最宝贵的资源。在这样的行业形势下,如何把内容创业做好?如何提高自身竞争力?如何在这场战争中武装自己?是每一位内容创业者都应该认真考虑的问题。 《内容创业:内容、分发、赢利新模式》旨在帮助内容创业者解决这些问题,为想要进入内容行业的创业者出谋划策,手把手教大家如何更好地进行内容创业,获得更高的......一起来看看 《内容创业:内容、分发、赢利新模式》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具