范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文

拿捏!隔离级别幻读GapLockNextKeyLock

  前面我写了很多Mysql相关的知识点,到这一篇稍微可以串一下了,从SQL执行流程、MVCC到锁,很多时候可能觉得对于间隙锁和Next-Key Lock好像已经理解了,但是好像又觉得理解差那么一点意思,这篇文章从头来梳理一下概念,明确一下这些知识。  锁
  首先,对于Mysql来说实现了两种行级锁:
  共享锁 :允许事务读一行数据,一般记为S,也称为读锁
  排他锁 :允许事务删除或者更新一行数据,一般记为X,也称为写锁
  关于读写锁的互斥性,应该都很清楚,读锁只能和读锁兼容,其他场景都无法兼容,这里不再赘述吧。
  隔离级别
  继续回顾下关于Mysql的4个隔离级别:
  读未提交Read Uncommitted :能读到其他事务还没有提交的数据,这种现象叫做脏读。
  读已提交Read Committed :只会读取其他事务已经提交的数据,所以不会产生RC的脏读问题。所以又带来一个问题叫做不可重复读,一个事务中两次一样的SQL查询可能查到的结果不一样。
  可重复读Repeatable Read :RR是Mysql的默认隔离级别,一个事务中两次SQL查询总是会查到一样的结果,不存在不可重复读的问题,但是还是会有幻读的问题。
  串行Serializable :串行场景没有任何问题,完全串行化的操作,读加读锁,写加写锁。
  幻读、Next-Key Lock、MVCC
  简单的回顾完了基础,那么我们看看RR级别下还会存在的幻读到底是什么问题,Mysql官方文档这样描述的:
  The so-called phantom problem occurs within a transaction when the same query produces different sets of rows at different times. For example, if a   SELECT   is executed twice, but returns a row the second time that was not returned the first time, the row is a "phantom" row.
  翻译过来就是,幻读指的是同一事务下,不同的时间点,同样的查询,得到不同的行记录的集合。
  如果说一个 select 执行了两次,但是第二次比第一次多出来行记录,这就是幻读。
  所以,对于幻读来说那一定是新增插入的数据!
  比如说在一个事务内,先查询 select * from user where age=10 for update ,得到的结果是id为[1,2,3]的记录,再次执行查询,得到了结果为[1,2,3,4]的记录,这是幻读。
  那怎么解决幻读的问题?以前我在文章里说解决幻读的原理是MVCC(MVCC原理看这里)很多网上的文章也有这么写的,其实不能说错,但是肯定也是不太对的,准确地来说应该是通过MVCC+Next-Key Lock的方式才解决了幻读的问题。
  对于MVCC中的读可以分为两种,分别叫做 快照读 和当前读 (这个当前读的说法我在书里翻了半天也没有找到,但是看网上一堆资料和大佬都叫当前读,那么我们就叫当前读吧,你知道的话可以告诉我哪本书有这个称呼,Mysql我只看见Lock reading或者锁定读的叫法,有的也说锁定读就是当前读,但是并没有找到当前读这种称呼的出处在哪儿)。
  快照读 就是简单的select 查询,查询的都是快照版本,这个场景下因为都是基于MVCC来查询快照的某个版本,所以不会存在幻读的问题,也可以认为是解决了幻读的方案之一,对于RC级别来说,因为每次查询都重新生成一个read view,也就是查询的都是最新的快照数据,所以会可能每次查询到不一样的数据,造成不可重复读,而对于RR级别来说只有第一次的时候生成read view,查询的是事务开始的时候的快照数据,所以就不存在不可重复读的问题,当然就更不可能有幻读的问题了。
  所以,现在我们说幻读,其实不是指快照读的场景,而是指的是当前读的场景。
  当前读 指的是lock in share mode 、for update  、insert 、update 、delete 这些需要加锁的操作。对于MVCC来说就是解决的快照读的场景,而对于当前读那么就是Next-Key Lock要解决的事情。
  那么Next-Key Lock是什么?怎么解决的幻读?
  行锁有写锁X和读锁S两种,实际上行锁有3种实现算法,Next-Key Lock是其中之一。
  第一种叫做 Record Lock ,字面意思,行记录的锁,实际上指的是对索引记录的锁定。
  比如执行语句 select * from user where age=10 for update ,将会锁住user 表所有age=10 的行记录,所有对age=10 的记录的操作都会被阻塞。
  第二种都比较熟悉,叫做 Gap Lock ,也就是间隙锁 ,它用于锁定的索引之间的间隙,但是不会包含记录本身。
  比如语句 select * from user where age>1 and age<10 for update ,将会锁住age 在(1,10)的范围区间,此时其他事务对该区间的操作都会被阻塞。
  间隙锁是可重复读RR隔离级别下特有的,另外还有几种场景也会不使用间隙锁。  事务隔离级别设置为不可重复读RC ,这样肯定没有间隙锁了。  Innodb_locks_unsafe_for_binlog 设置为1 另外一种情况适用于 主键索引或者唯一索引 的等值查询条件,比如select * from user where id=1 ,id 是主键索引,这样只使用Record Lock就可以了,因为能唯一锁定一条记录,所以没有必要再加间隙锁了,这是锁降级的过程。
  而第三种 Next-Key Lock 实际上就是相当于Record Lock+Gap Lock的组合。比如索引有10,20,30几个值,那么被锁住的区间可能会是(-∞,10],(10,20],(20,30],(30,+∞)。 解决幻读
  上一篇关于更新SQL执行过程我们已经对这个基础有了一定的了解,在这里我们去掉和这里内容无关的一些日志的细节,把给数据加锁的流程加入进去,这样通过SQL执行可以更好地理解Next-Key Lock到底是如何解决幻读的,执行过程如下:
  首先第一步Server层会来查询数据 存储引擎根据查询条件查到数据之后对数据进行加锁,Record Lock或者间隙锁,然后返回数据 Server层拿到数据之后调用API去存储引擎更新数据 最后存储引擎返回结果,流程结束
  搞一张表说明一下, user 表有4个字段,id 是主键索引,name 是唯一索引,age 是普通索引,city 没有索引,然后插入一些测试数据,下面区分一下几种情况来说明是怎么加Next-Key Lock的,然后就知道为啥会没有幻读的问题了。
  没有索引
  更新语句 update user set city="nanjing" where city="wuhan" 会发生什么?
  因为 city 是没有索引的,所以存储引擎只能给所有的记录都加上锁,然后把数据都返回给Server层,然后Server层把city 改成nanjing ,再更新数据。
  因此,首先Record Lock会锁住现有的7条记录,间隙锁则会对主键索引的间隙全部加上间隙锁。
  所以,更新的时候没有索引是非常可怕的一件事情,相当于把整个表都给锁了,那表都给锁了当然不存在幻读了。
  普通索引
  我们再假设一个语句 select * from user where age=20 for update 。
  因为 age 是一个普通索引,存储引擎根据条件过滤查到所有匹配age=20 的记录,给他们加上写锁,间隙锁会加在(10,20),(20,30)的区间上,因此现在无论怎样都无法插入age=20 的记录了
  为什么要锁定这两个区间?如果不锁定这两个区间的话,那么还能插入比如 id=11,age=20 或者id=21,age=20 的记录,这样就存在幻读了。
  (那实际上写锁不光是在会加在 age 普通索引上,还会加在主键索引上,因为数据都是在主键索引下对吧,这个肯定也要加锁的,为了看起来简单点,就不画出来了)
  唯一&主键索引
  如果查询的是唯一索引又会发生什么呢?比如有查询语句 select * from user where name="b" for update 。
  上面我们提到过,如果是唯一索引或者主键索引的话,并且是等值查询,实际上会发生锁降级,降级为Record Lock,就不会有间隙锁了。
  因为主键或者唯一索引能保证值是唯一的,所以也就不需要再增加间隙锁了。
  很显然,是无法插入 name=b 的的记录的,也不存在幻读问题。
  如果是范围查询比如 id>1 and id<11 呢,实际上也是一样的锁定方式,不再赘述。
  相比稍微有点不同的是上面也说过,唯一索引不光锁定唯一索引,还会锁定主键索引,主键索引的话只要索引主键索引就行了。
  总结
  那最后说了这么多,RR级别下不是都已经解决了幻读的问题吗,怎么还说有幻读的问题呢?
  关于这个问题,可以看看这个报出的BUGhttps://bugs.mysql.com/bug.php?id=63870,回复说了这不是BUG,这是符合隔离规范的设计,有兴趣的自己看看吧。

刘亦菲杨幂关晓彤景甜四个人中选一个结婚,你选谁?为什么选择她?门不当户不对,百姓找百姓,豪门找豪门。这四大美女,个各不是省油的灯,娶不起,真是白日做梦,天下掉馅饼。刘亦菲演神雕俠侣时呆萌呆萌的,应该很好上手。杨幂是个人精,花容月貌,小鸟依人娇童星出道的6位艺人,张一山吴磊为何只能用命拼?资本扶持是关键都说一个人一个命,一个人一条路,但是在娱乐圈中,这同样是童星出道的6位艺人,长大之后这命运也确实差得有点多了。纵观童星出道的明星,下面这6位算是比较出名的了,可其中张一山和吴磊却给冯小刚赔了2个多亿,为什么还偷着乐?作者东方鸿鹄微信公众号针见主笔没事偷着乐,是1999年上映的一部老片,由著名相声演员冯巩领衔主演。20多年后,著名导演冯小刚亲自上阵,演绎了一次没事偷着乐的财富故事。故事梗概是这样曹格10岁女儿近照变样,包子脸不在五官变立体,曾因长相被嘲讽5月8日,台湾歌手曹格的太太在社交平台晒出10岁女儿grace的近照,引发网友热议。照片中,grace乖巧的坐在床上,不复幼儿时期的包子脸,五官变得很立体。她戴着一个粉色发带,调皮泰国女星Ploy确诊新冠泰国网报道,5月9日,泰国知名女星PloyChermarn通过个人社交账号对外公布了自己确诊新冠的消息,并公布了近期的行程活动轨迹。Ploy向所有因她确诊而受到影响的人致歉,并感谢公认的大孝子,为父还债而退学入圈,事成后马上又退圈了吗?大家还记得2006年的台湾偶像剧微笑Pasta吗,当时可真是风靡大街小巷,男主何群是偶像小天王,乐队主唱,一出场就会被粉丝围住的人,女主成晓诗是个性格略显鲁莽,还有些倔强,但是很有冯绍峰离婚没多久就被爆出相亲,当初的爱妻都是假的?本来我们最看好的一对夫妻赵丽颖和冯绍峰也在前一段时间火速官宣离婚,我们原本以为他们当初没办婚礼,可能现在赵丽颖生了孩子了戏也杀青了,手上的活都忙完了,可能会腾出时间来办婚礼。没想到胡歌我真没你们想得那么好!作者木棉姐姐文章来源公众号悦读(IDyuedu58)注本文部分图片来自于网络,如有侵权请联系。朗读君saying我始终相信,经历过死亡的人,一定会更加敬畏生命。01hr曾看过一个高陈凯歌管虎宁浩等人共同拍摄,我和我的祖国定档国庆3月20日,电影我和我的祖国在北京中国电影导演中心举行了盛大的启动仪式,并发布首张概念海报,正式宣布影片定档2019年国庆。影片由华夏电影发行有限责任公司出品,陈凯歌担任总导演,黄早就说过,综艺不会在掌声中结束上周,有关第五季极限挑战阵容的话题,一定成为了节目粉丝议论的焦点。正如大家在节目官博上看到的,坚持了四季的固定MC阵容发生了巨大变化。孙红雷和黄渤已经确定不在名单中,新增了迪丽热巴王晓棠无数60后心中白月光,经历丧子丧夫,88岁依旧优雅坚强王晓棠荣誉不应当成为追逐名利的资本,而应是继续前行的动力。2021年12月20日,87岁的王晓棠在光影中国荣誉盛典中,如是说道。镜头下的她,模样不过半百,行为举止平和优雅,一颦一笑
王思聪现身斗鱼直播间!欣赏舞蹈才艺并大气豪刷女主播王思聪作为网红收集者在各大平台均注册有自己的账号,因此时不时便会现身欣赏艺术。昨晚,王思聪便再次现身斗鱼,并在知名舞蹈区女主播舞法天女小慕林的直播间大气豪刷!据悉,昨晚王思聪来到小神豪青蛙被曝存在违规行为!直播回应,因言辞过激遭到封禁近期,短视频平台中突然出现了一位名为正义怒喊的神秘人士。其以知情人的身份对虎牙官方运营公会神豪团土豪大哥进行了一番大爆料。尽管爆料的真实性难以保证,但却仍旧获得了不少人的关注。由于虎牙迎来女神豪!豪刷百万,称玩虎牙能花几个钱?近日,虎牙娱乐板块可谓是平静得可怕!老牌神豪因玩通关失去兴趣等因素逐渐淡出游客的视野而新一批的神豪大哥们却还没有出现。这使得虎牙娱乐版块不论是热度营收都呈现断崖式下降!为了改变虎牙虎牙新神豪,豪刷百万,开通超皇!表示想低调一点!近日,虎牙娱乐板块颇为平静。曾经的神豪大哥逐渐隐退淡出人们的视野,而新一批神豪却还未登场,这使得虎牙娱乐主播热度营收大幅下降。为了刺激消费,扭转娱乐秀场的萎靡态势,虎牙官方推出了超斗鱼神豪茶姐造假风波后,首次现身豪刷!力破抹黑造谣不久前,斗鱼知名女神豪抹茶不要绿被爆出猛料,直指其身份造假豪刷的鱼翅来历不明。一时间网络上充斥着多种关于神豪抹茶不要绿事件的相关猜测,可信度比较高的有两种茶姐实为某公司会计茶姐实为虎牙外籍主播发表不当言论被封禁!如今道歉称绝无任何仇视四月中旬,虎牙知名户外主播李俊在直播时公然发表不当言论,称四川是丢脸,同桌喝酒的男子来自怂国!事情发生不久后,虎牙官方便将其直播间封禁,但仅过了几天,这位涉嫌发表不当言论的外籍主播虎牙集梦公会内斗升级!集梦会长阿布激烈争执后,纷纷停播近日,虎牙知名公会集梦传媒内部接连发生激烈争执先是旗下户外主播志峰与文斌两人切磋了一番武艺,由于众人的阻拦,并未产生更严重的后果接着集梦会长又与阿布发生了争吵,期间集梦会长向阿布放虎牙户外一哥在石250获两大神豪支持,一场pk豪刷百万近日,虎牙户外主播在石250可谓是迎来了直播事业的新巅峰,接连获得多位顶级神豪大哥的金豆支持虎牙神豪小金库上山了斗鱼抖音神豪啊南很忙嘎均为其豪刷近百万!由于直播间有两大神豪坐镇,因神豪宝亮豪刷千万,未获女主播芳心!如今自曝已结婚!提及虎牙神豪大哥宝亮,相信时常观看直播的小伙伴一定不会感到陌生。宝亮哥在虎牙总计豪刷千万以上,是一位十足的神豪大哥。起初,宝亮哥作为一个小白号,一直守护着一位虎牙跳舞女主播。之后通榜一豪刷百万,被女主播拒绝!称求放过!别再给我刷!提及女主播,相比大家脑海里第一时间浮现出的词语都是拜金虚荣之类的负面词汇。抱住榜一大腿不放,疯狂吸金似乎才是是女主播们的常态。而斗鱼颜值区的一位女主播颐颐儿却反其道而行之!不仅不抱封号斗罗!世界级后羿酷酷的鑫涉嫌低俗,直播间当场被封提及有着世界级后羿之称(自封)的虎牙王者荣耀主播酷酷的鑫,相比各位小伙伴一定不会感到陌生!自五月初,酷酷的鑫自曝欠巨额债款后,他似乎就改变了自己的直播风格。作为一名王者荣耀主播,不