共享锁和排它锁

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. tomcat线程初探

    博主:handsomecui,希望路过的各位大佬留下你们宝贵的意见,在这里祝大家冬至快乐. 缘由: 初探缘由,在业务层想要通过(当前线程的栈)来获取到控制层的类名,然后打日志,可是发现并不能通过当前线 ...

  2. 如何在BIOS里设置定时关机?

    如何在BIOS里设置定时关机? 通过CMOS设置实现定时开机的设置过程如下: 首先进入"CMOS SETUP"程序(大多数主板是在计算机启动时按DEL键进入): 然后将光条移到&q ...

  3. Linux学习记录--文件IO操作相关系统编程

    文件IO操作相关系统编程 这里主要说两套IO操作接口,各自是: POSIX标准 read|write接口.函数定义在#include<unistd.h> ISO C标准 fread|fwr ...

  4. 给新手--安装tomcat后username和password设置以及项目怎么部署在tomcatserver上

    安装后tomcatserver后.登陆首先就是让输入username和password.但是我们在安装tomcat的过程中好像没有让设置username和password,这时候可能有人就抓狂了.还有 ...

  5. jar包后台启动--nohup篇

    直接java -jar TestHttps-0.0.1-SNAPSHOT.jar的话是前段启动,但是窗口关闭之类的程序也就关闭了 我们可以nohup java -jar TestHttps-0.0.1 ...

  6. 48、mysql补充

    一 视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,可以将该结果集当做表来使用. 使用视图我们可以把查询过程中的 ...

  7. 【MySQL】查看支持的字符集show character set;

  8. iOS masonry九宫格 单行 多行布局

    Masonry是个好东西,在当前尺寸各异的iOS开发适配中发挥着至关重要的作用,由于项目中Masonry布局用的比较多,对于UI布局也有了一些自己的理解,经常会有人问道Masonry布局九宫格要怎么布 ...

  9. c#创建access数据库和数据表

      由于在程序中使用了ADOX,所以先要在解决方案中引用之,方法如下: 解决方案资源管理器(项目名称)-->(右键)添加引用-->COM--> Microsoft ADO Ext. ...

  10. Wincc flexable的局势视图的组态

    1.趋势视图介绍 2.实时趋势视图的组态 1)创建连接和变量 2)开始组态局势视图 3)设置趋势视图的属性,添加一个趋势 3.模拟运行HMI,观察局势图