共享锁和排它锁

InnoDB实现了标准的行级锁,包括两种类型:共享锁(S)和排它锁(X)

  • 一个共享锁(S)允许事务持有这种锁来读取一行
  • 一个排它锁(X)允许事务持有这种锁来修改或删除一行

如果事务T1对行r持有一个共享锁(S),那么来自其它事务T的对于行r的锁的请求处理如下:

  • 如果T2请求的是共享锁(S),那么将立即被授予共享锁。这样的话,T1和T2都持有r的共享锁(S)
  • 如果T2请求的是排它锁,则不能被立即授予

如果事务T1持有行r的排它锁,那么来自其它事务T2对r的任何锁请求都不能被立即授予。此时,T2必须等待T1释放对r锁持有的锁。

意向锁

InnoDB支持多种粒度的锁,它允许行级别的锁和表级别的锁共存。为了支持多种粒度级别的锁,需要用到另外一种锁,叫意向锁。在InnoDB中,意向锁是表级别的锁,它表示稍后会锁定表中的一行。有两种类型的意向锁:

  • 意向共享锁(IS):事务T打算在表t中的某个行上设置共享锁(S)
  • 共享排它锁(IX):事务T打算在这些行上设置排它锁(X)

例如,SELECT ... LOCK IN SHARE MODE将设置一个IS锁,而SELECT ... FOR UPDATE将设置一个IX锁

意向锁协议如下:

  • 一个事务在获得表t上的某一行的共享锁(S)之前,它必须先在表t上获得意向共享锁(IS)或者更高级别的锁
  • 一个事务在获得表t上的某一行的排它锁(X)之前,它必须现在表t上获得意向排它锁(IX)

一个锁被授予一个事务请求必须保证和已经存在的锁兼容,如果冲突的话将不能被授予。一个事务必须等待知道和它想获得的锁冲突的存在的锁被释放。

记录锁

一个记录锁是一种在索引记录上的锁。例如,SELECT c1 FROM t WHERE c1 = 10 FOR UPDATE;阻止其它事务对t.c1=10的行的添加修改删除操作。

记录锁总是锁定索引记录,即使表没有定义索引。对这种情况,InnoDB会创建隐藏的索引,并且用这个索引来加锁。

间隙锁

一个间隙锁是加在索引记录之间的间隙的锁,或者在第一个索引记录之前或者在最后一个索引记录之后的锁。例如,SELECT c1 FROM t WHERE c1 BETWEEN 10 AND 20 FOR UPDATE;阻止其它事务插入一个值15在t.c1列上,因为在这个范围内的所有存在的值的间隙之间已经被锁定。

一个间隙可能跨过一个单个的索引值,也可能跨过是多个索引值,甚至是空。

间隙锁是在性能和一致性上的一个折中的方式,它被用在某些事物隔离级别上。

Next-Key锁

一个next-key锁是一个在索引记录上的记录锁和一个在索引记录之前的间隙的间隙锁的一个结合。

InnoDB允许行级别的锁以这样的方式,当它搜索或者扫描一个表的索引时,会给它扫描到的索引记录设置共享或排它锁。因此,行级别的锁实际上是索引记录锁,一个next-key锁是一个索引记录锁加上一个在索引记录之前的间隙的间隙锁。如果一个会话持有一个索引记录R的共享或者排它锁,那么另外一个会话不能在这个记录R之前插入新的索引值。

假设一个索引包含的值有:10、11、13、20,那么对这个索引的next-key锁会包含下面这样几个间隔,也就是说锁定范围覆盖这些区间:

这是前开后闭区间

默认情况下,InnoDB的默认隔离级别是REPEATABLE_READ。在这种情况下,对于检索和索引扫描,InnoDB使用next-key锁。

总结:

1、记录锁是索引记录上的锁

2、间隙锁是索引记录之间的间隙的锁

3、next-key锁是记录锁加上间隙锁

4、行级别锁实际上是记录锁

5、意向锁是表级别的锁

参考 https://dev.mysql.com/doc/refman/5.7/en/innodb-locking.html

InnoDB锁的更多相关文章

  1. innodb 锁分裂继承与迁移

    innodb行锁简介 行锁类型 LOCK_S:共享锁 LOCK_X: 排他锁 GAP类型 LOCK_GAP:只锁间隙 LOCK_REC_NO_GAP:只锁记录 LOCK_ORDINARY: 锁记录和记 ...

  2. InnoDB锁机制分析

    InnoDB锁机制常常困扰大家,不同的条件下往往表现出不同的锁竞争,在实际工作中经常要分析各种锁超时.死锁的问题.本文通过不同条件下的实验,利用InnoDB系统给出的各种信息,分析了锁的工作机制.通过 ...

  3. MySQL数据恢复和复制对InnoDB锁机制的影响

    MySQL通过BINLOG记录执行成功的INSERT,UPDATE,DELETE等DML语句.并由此实现数据库的恢复(point-in-time)和复制(其原理与恢复类似,通过复制和执行二进制日志使一 ...

  4. [转载] 数据库分析手记 —— InnoDB锁机制分析

    作者:倪煜 InnoDB锁机制常常困扰大家,不同的条件下往往表现出不同的锁竞争,在实际工作中经常要分析各种锁超时.死锁的问题.本文通过不同条件下的实验,利用InnoDB系统给出的各种信息,分析了锁的工 ...

  5. mysql innodb锁简析(2)

    继续昨天的innodb锁的分析: 注:此博文参考一下地址,那里讲的也很详细.http://xm-king.iteye.com/blog/770721 mysql事务的隔离级别分为四种,隔离级别越高,数 ...

  6. MySQL · 特性分析 · innodb 锁分裂继承与迁移

    http://mysql.taobao.org/monthly/2016/06/01/ innodb行锁简介 行锁类型 LOCK_S:共享锁 LOCK_X: 排他锁 GAP类型 LOCK_GAP:只锁 ...

  7. Innodb 锁系列2 事务锁

    上一篇介绍了Innodb的同步机制锁:Innodb锁系列1 这一篇介绍一下Innodb的事务锁,只所以称为事务锁,是因为Innodb为实现事务的ACID特性,而添加的表锁或者行级锁. 这一部分分两篇来 ...

  8. Innodb 锁 (简单笔记)

    看过很多innodb锁的文章,已经明白的就不写了,简单做个笔记   Innodb 锁的兼容性: 1.意向锁和意向锁之间都是兼容的 2.X(排他锁)与任何锁都是不兼容的 3.排他意向锁 IX 于S锁是不 ...

  9. MySQL- InnoDB锁机制

    InnoDB与MyISAM的最大不同有两点:一是支持事务(TRANSACTION):二是采用了行级锁.行级锁与表级锁本来就有许多不同之处,另外,事务的引入也带来了一些新问题.下面我们先介绍一点背景知识 ...

  10. MySQL InnoDB锁机制

    概述: 锁机制在程序中是最常用的机制之一,当一个程序需要多线程并行访问同一资源时,为了避免一致性问题,通常采用锁机制来处理.在数据库的操作中也有相同的问题,当两个线程同时对一条数据进行操作,为了保证数 ...

随机推荐

  1. 安装cuda8.0中所遇到的问题-解决办法

    正是申请季高峰,但还是被老师抓着干活.之前一直以为cuda已经装好,才知道是骗自己的.我的显卡是640,ubuntu14.4, 比较low. 我是按照这个教程走的,http://m.blog.csdn ...

  2. 《3》CentOS7.0+OpenStack+kvm云平台部署—配置Glance

    感谢朋友支持本博客,欢迎共同探讨交流.因为能力和时间有限,错误之处在所难免,欢迎指正. 假设转载.请保留作者信息. 博客地址:http://blog.csdn.net/qq_21398167 原博文地 ...

  3. [基础规范]JavaBeans规范

    本文来自维基百科:http://en.wikipedia.org/wiki/JavaBeans#JavaBean_conventions JavaBeans是Java语言中能够反复使用的软件组件,它们 ...

  4. cocos2dx中关于Action动作的相关API的具体介绍

     //CCMoveBy  创建一个移动的动作 //參数1:移动到目标坐标所需的时间 //參数2:目标坐标 //支持reverse 能够获取其反向动作 //CCMoveTo  一样的 //CCAct ...

  5. Matlab 2014b For Mac安装破解

    1.Matlab 2014b 的安装和破解文件下载: 安装文件:http://www.cncrk.com/downinfo/80718.html 破解文件:http://pan.baidu.com/s ...

  6. 入门vue----(介绍)

    声明式渲染 Vue.js 的核心是一个允许采用简洁的模板语法来声明式的将数据渲染进 DOM 的系统: <div id="app"> {{ message }} < ...

  7. Docker + Jenkins 持续部署 ASP.NET Core 项目

    Docker 是个好东西,特别是用它来部署 ASP.NET Core Web 项目的时候,但是仅仅的让程序运行起来远远不能满足我的需求,如果能够像 DaoCloud 提供的持续集成服务那样,检测 gi ...

  8. 如何在MAC上安装SSHFS

    找了半天,试了各种方法,最后一种可行的方法. macOS 版本 10.12.6 具体看下面的说明: 安装Fuse 下载 osxfuse-3.6.3.dmg 并且安装. 链接 安装sshfs 下载ssh ...

  9. springboot命令启动

    gradle打jar包命令 jar { doFirst { def jarFiles = ''; configurations.compile.collect { jarFiles += it.nam ...

  10. mac下通过mdfind命令搜索文件

    mdfind命令就是Spotlight功能的终端界面,这意味着如果Spotlight被禁用,mdfind命令也将无法工作.mdfind命令非常迅速.高效.最基本的使用方法是: mdfind -name ...