电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

MySQL 鎖的相關(guān)知識(shí)總結(jié)

瀏覽:68日期:2023-10-06 12:26:29
MySQL中的鎖

鎖是為了解決并發(fā)環(huán)境下資源競(jìng)爭(zhēng)的手段,其中樂(lè)觀并發(fā)控制,悲觀并發(fā)控制和多版本并發(fā)控制是數(shù)據(jù)庫(kù)并發(fā)控制主要采用的技術(shù)手段(具體可見(jiàn)我之前的文章),而MySQL中的鎖就是其中的悲觀并發(fā)控制。

MySQL中的鎖有很多種類(lèi),我們可以按照下面方式來(lái)進(jìn)行分類(lèi)。

按讀寫(xiě)

從數(shù)據(jù)庫(kù)的讀寫(xiě)的角度來(lái)分,數(shù)據(jù)庫(kù)的鎖可以分為分為以下幾種:

獨(dú)占鎖:又稱(chēng)排它鎖、X鎖、寫(xiě)鎖。X鎖不能和其他鎖兼容,只要有事務(wù)對(duì)數(shù)據(jù)上加了任何鎖,其他事務(wù)就不能對(duì)這些數(shù)據(jù)再放置X了,同時(shí)某個(gè)事務(wù)放置了X鎖之后,其他事務(wù)就不能再加其他任何鎖了,只有獲取排他鎖的事務(wù)是可以對(duì)數(shù)據(jù)進(jìn)行讀取和修改。 共享鎖:又稱(chēng)讀鎖、S鎖。S鎖與S鎖兼容,可以同時(shí)放置。 更新鎖:又稱(chēng)U鎖。它允許再加S鎖,但不允許其他事務(wù)再施加U鎖或X鎖,當(dāng)被讀取的數(shù)據(jù)要被更新時(shí),則升級(jí)S鎖為X鎖。U鎖的優(yōu)點(diǎn)是允許事務(wù)A讀取數(shù)據(jù)的同時(shí)不阻塞其它事務(wù),并同時(shí)確保事務(wù)A自從上次讀取數(shù)據(jù)后數(shù)據(jù)沒(méi)有被更改,因此可以減少X鎖和S鎖的沖突,同時(shí)避免使用S鎖后再升級(jí)為X鎖造成的死鎖現(xiàn)象。注意,MySQL并不支持U鎖,SQLServer才支持U鎖。

兼容性矩陣如下(+ 代表兼容, -代表不兼容)

右側(cè)是已加的鎖 X S U X - - - S - + + U - + -

按粒度

MySQL支持不同級(jí)別的鎖,其鎖定的數(shù)據(jù)的范圍也不同,也即我們常說(shuō)的鎖的粒度。MySQL有三種鎖級(jí)別:行級(jí)鎖、頁(yè)級(jí)鎖、表級(jí)鎖。不同的存儲(chǔ)引擎支持不同的鎖粒度,例如MyISAM和MEMORY存儲(chǔ)引擎采用的是表級(jí)鎖,頁(yè)級(jí)鎖僅被BDB存儲(chǔ)引擎支持,InnoDB存儲(chǔ)引擎支持行級(jí)鎖和表級(jí)鎖,默認(rèn)情況下是采用行級(jí)鎖。

特點(diǎn)

表級(jí)鎖:開(kāi)銷(xiāo)小,加鎖快;不會(huì)出現(xiàn)死鎖;鎖定粒度大,發(fā)生鎖沖突的概率最高,并發(fā)度最低。數(shù)據(jù)庫(kù)引擎總是一次性同時(shí)獲取所有需要的鎖以及總是按相同的順序獲取表鎖從而避免死鎖。行級(jí)鎖:開(kāi)銷(xiāo)大,加鎖慢;會(huì)出現(xiàn)死鎖;鎖定粒度最小,發(fā)生鎖沖突的概率最低,并發(fā)度也最高。行鎖總是逐步獲得的,因此會(huì)出現(xiàn)死鎖。頁(yè)面鎖:開(kāi)銷(xiāo)和加鎖時(shí)間界于表鎖和行鎖之間;會(huì)出現(xiàn)死鎖;鎖定粒度界于表鎖和行鎖之間,并發(fā)度一般。

下面詳細(xì)介紹行鎖和表鎖,頁(yè)鎖由于使用得較少就不介紹了。

行鎖

按行對(duì)數(shù)據(jù)進(jìn)行加鎖。InnoDB行鎖是通過(guò)給索引上的索引項(xiàng)加鎖來(lái)實(shí)現(xiàn)的,Innodb一定存在聚簇索引,行鎖最終都會(huì)落到聚簇索引上,通過(guò)非聚簇索引查詢的時(shí)候,先鎖非聚簇索引,然后再鎖聚簇索引。如果一個(gè)where語(yǔ)句里面既有聚簇索引,又有二級(jí)索引,則會(huì)先鎖聚簇索引,再鎖二級(jí)索引。由于是分步加鎖的,因此可能會(huì)有死鎖發(fā)生。

MySQL的行鎖對(duì)S、X鎖上做了一些更精確的細(xì)分,使得行鎖的粒度更細(xì)小,可以減少?zèng)_突,這就是被稱(chēng)為“precise mode”的兼容矩陣。(該矩陣沒(méi)有出現(xiàn)在官方文檔上,是有人通過(guò)Mysql lock0lock.c:lock_rec_has_to_wait源代碼推測(cè)出來(lái)的。)

行鎖兼容矩陣 間隙鎖(Gap Lock):只鎖間隙,前開(kāi)后開(kāi)區(qū)間(a,b),對(duì)索引的間隙加鎖,防止其他事務(wù)插入數(shù)據(jù)。 記錄鎖(Record Lock):只鎖記錄,特定幾行記錄。 臨鍵鎖(Next-Key Lock):同時(shí)鎖住記錄和間隙,前開(kāi)后閉區(qū)間(a,b]。 插入意圖鎖(Insert Intention Lock):插入時(shí)使用的鎖。在代碼中,插入意圖鎖,實(shí)際上是GAP鎖上加了一個(gè)LOCK_INSERT_INTENTION的標(biāo)記。

右側(cè)是已加的鎖(+ 代表兼容, -代表不兼容) G R N I G + + + + R + ? ? + N + ? ? + I ? + ? +

S鎖和S鎖是完全兼容的,因此在判別兼容性時(shí)不需要對(duì)比精確模式。精確模式的檢測(cè),用在S、X和X、X之間。從這個(gè)矩陣可以看到幾個(gè)特點(diǎn):

INSERT操作之間不會(huì)有沖突:你插入你的,我插入我的。 GAP,Next-Key會(huì)阻止Insert:插入的數(shù)據(jù)正好在區(qū)間內(nèi),不允許插入。 GAP和Record,Next-Key不會(huì)沖突 Record和Record、Next-Key之間相互沖突。 已有的Insert鎖不阻止任何準(zhǔn)備加的鎖。 間隙鎖(無(wú)論是S還是X)只會(huì)阻塞insert操作。 注意點(diǎn) 對(duì)于記錄鎖,列必須是唯一索引列或者主鍵列,查詢語(yǔ)句必須為精確匹配,如“=”,否則記錄鎖會(huì)退化為臨鍵鎖。 間隙鎖和臨鍵鎖基于非唯一索引,在唯一索引列上不存在間隙鎖和臨鍵鎖。 表鎖與鎖表的誤區(qū)

只有正確通過(guò)索引條件檢索數(shù)據(jù)(沒(méi)有索引失效的情況),InnoDB才會(huì)使用行級(jí)鎖,否則InnoDB對(duì)表中的所有記錄加鎖,也就是將鎖住整個(gè)表。注意,這里說(shuō)的是鎖住整個(gè)表,但是Innodb并不是使用表鎖來(lái)鎖住表的,而是使用了下面介紹的Next-Key Lock來(lái)鎖住整個(gè)表。網(wǎng)上很多的說(shuō)法都是說(shuō)用表鎖,然而實(shí)際上并不是,我們可以通過(guò)下面的例子來(lái)看看。

假設(shè)我們有以下的數(shù)據(jù)(MySQL8):

mysql> select * from users;+----+------+-----+| id | name | age |+----+------+-----+| 1 | a | 1 || 2 | a | 1 || 3 | a | 1 || 4 | a | 1 || 5 | a | 1 |+----+------+-----+

方法一:

我們使用表鎖鎖表,并查看引擎的狀態(tài)

mysql> begin;Query OK, 0 rows affected (0.00 sec)mysql> lock tables users write;Query OK, 0 rows affected (0.00 sec)mysql> show engine innodb statusG...------------TRANSACTIONS------------Trx id counter 4863Purge done for trx’s n:o < 4862 undo n:o < 0 state: running but idleHistory list length 911LIST OF TRANSACTIONS FOR EACH SESSION:---TRANSACTION 281479760456232, not startedmysql tables in use 1, locked 1 ###############注意這里0 lock struct(s), heap size 1136, 0 row lock(s)...

然后我們?cè)偻ㄟ^(guò)非索引的字段查詢來(lái)加鎖,并查看引擎的狀態(tài)

## 先解鎖上次的表鎖mysql> unlock tables;Query OK, 0 rows affected (0.00 sec)mysql> commit;Query OK, 0 rows affected (0.00 sec)mysql> begin;Query OK, 0 rows affected (0.00 sec)mysql> select * from users where name = ’a’ for update;mysql> show engine innodb statusG...------------TRANSACTIONS------------Trx id counter 4864Purge done for trx’s n:o < 4862 undo n:o < 0 state: running but idleHistory list length 911LIST OF TRANSACTIONS FOR EACH SESSION:---TRANSACTION 4863, ACTIVE 37 sec2 lock struct(s), heap size 1136, 6 row lock(s) ###############注意這里...

然后我們?cè)賱h除id為2,3,4的數(shù)據(jù),然后在通過(guò)非索引的字段查詢來(lái)加鎖,并查看引擎的狀態(tài)

mysql> delete from users where id in (2,3,4);Query OK, 3 rows affected (0.00 sec)mysql> commit;Query OK, 0 rows affected (0.00 sec)mysql> begin;Query OK, 0 rows affected (0.00 sec)mysql> select * from users where name = ’a’ for update;mysql> show engine innodb statusG...------------TRANSACTIONS------------Trx id counter 4870Purge done for trx’s n:o < 4869 undo n:o < 0 state: running but idleHistory list length 914LIST OF TRANSACTIONS FOR EACH SESSION:---TRANSACTION 4869, ACTIVE 9 sec2 lock struct(s), heap size 1136, 3 row lock(s) ###############注意這里...

可以看到這里使用了表鎖和因?yàn)闆](méi)法用索引鎖定特定行而轉(zhuǎn)而鎖住整個(gè)表是不一樣的。從第二次和第三次的操作來(lái)看,lock住的row也是不同的,這是因?yàn)閮烧唛g隙的個(gè)數(shù)不同,所以可以看到使用的并不是表鎖,而是Next-Key Lock。第一次鎖住了(-∞,1],(1,2],(2,3],(3,4],(4,5],(5,∞],第二次鎖住了(-∞,1],(1,5],(5,∞]。

方法二:

也可以通過(guò)以下語(yǔ)句來(lái)查看鎖的信息,也可以知道用的是行鎖,且是鎖住了區(qū)間(插入不了數(shù)據(jù))和記錄,所以是Next-Key Lock。

mysql> select ENGINE_TRANSACTION_ID,LOCK_TYPE,LOCK_MODE from performance_schema.data_locks where ENGINE_TRANSACTION_ID in (你的事務(wù)id);+-----------------------+-----------+-----------+| ENGINE_TRANSACTION_ID | LOCK_TYPE | LOCK_MODE |+-----------------------+-----------+-----------+| 4889 | TABLE | IX || 4889 | RECORD | X || 4889 | RECORD | X || 4889 | RECORD | X |+-----------------------+-----------+-----------+10 rows in set (0.00 sec)

LOCK_TYPE:對(duì)于InnoDB,可選值為 RECORD(行鎖), TABLE(表鎖)

LOCK_MODE:對(duì)于InnoDB,可選值為S[,GAP], X[,GAP], IS[,GAP],IX[,GAP], AUTO_INC和UNKNOWN。除了AUTO_INC和UNKNOWN,其他鎖定模式都包含了GAP鎖(如果存在)。

具體可見(jiàn) MySQL文檔:https://dev.mysql.com/doc/ref...

表級(jí)鎖

直接對(duì)整個(gè)表加鎖,影響表中所有記錄,表讀鎖和表寫(xiě)鎖的兼容性見(jiàn)上面的分析。

MySQL中除了表讀鎖和表寫(xiě)鎖之外,還存在一種特殊的表鎖:意向鎖,這是為了解決不同粒度的鎖的兼容性判斷而存在的。

意向鎖

因?yàn)殒i的粒度不同,表鎖的范圍覆蓋了行鎖的范圍,所以表鎖和行鎖會(huì)產(chǎn)生沖突,例如事務(wù)A對(duì)表中某一行數(shù)據(jù)加了行鎖,然后事務(wù)B想加表鎖,正常來(lái)說(shuō)是應(yīng)該要沖突的。如果只有行鎖的話,要判斷是否沖突就得遍歷每一行數(shù)據(jù)了,這樣的效率實(shí)在不高,因此我們就有了意向表鎖。

意向鎖的主要目的是為了使得 行鎖 和 表鎖 共存,事務(wù)在申請(qǐng)行鎖前,必須先申請(qǐng)表的意向鎖,成功后再申請(qǐng)行鎖。注意:申請(qǐng)意向鎖的動(dòng)作是數(shù)據(jù)庫(kù)完成的,不需要開(kāi)發(fā)者來(lái)申請(qǐng)。

意向鎖是表級(jí)鎖,但是卻表示事務(wù)正在讀或?qū)懩骋恍杏涗洠皇钦麄€(gè)表, 所以意向鎖之間不會(huì)產(chǎn)生沖突,真正的沖突在加行鎖時(shí)檢查。

意向鎖分為意向讀鎖(IS)和意向?qū)戞i(IX)。

表鎖的兼容性矩陣

右側(cè)是已加的鎖(+ 代表兼容, -代表不兼容) IS IX S X IS + + + ? IX + + ? ? S + ? + ? X ? ? ? ?

以上就是MySQL 鎖的相關(guān)知識(shí)總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于MySQL 鎖的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
主站蜘蛛池模板: 薪动-人力资源公司-灵活用工薪资代发-费用结算-残保金优化-北京秒付科技有限公司 | 真空粉体取样阀,电动楔式闸阀,电动针型阀-耐苛尔(上海)自动化仪表有限公司 | 一体化净水器_一体化净水设备_一体化水处理设备-江苏旭浩鑫环保科技有限公司 | 杭州顺源过滤机械有限公司官网-压滤机_板框压滤机_厢式隔膜压滤机厂家 | 冷凝水循环试验箱-冷凝水试验箱-可编程高低温试验箱厂家-上海巨为(www.juweigroup.com) | 沈阳激光机-沈阳喷码机-沈阳光纤激光打标机-沈阳co2激光打标机 | 杭州|上海贴标机-百科| 卡诺亚轻高定官网_卧室系统_整家定制_定制家居_高端定制_全屋定制加盟_定制家具加盟_定制衣柜加盟 | 翅片管散热器价格_钢制暖气片报价_钢制板式散热器厂家「河北冀春暖气片有限公司」 | 自动螺旋上料机厂家价格-斗式提升机定制-螺杆绞龙输送机-杰凯上料机 | 深圳彩钢板_彩钢瓦_岩棉板_夹芯板_防火复合彩钢板_长鑫 | 钢格板|镀锌钢格板|热镀锌钢格板|格栅板|钢格板|钢格栅板|热浸锌钢格板|平台钢格板|镀锌钢格栅板|热镀锌钢格栅板|平台钢格栅板|不锈钢钢格栅板 - 专业钢格板厂家 | 除尘器布袋骨架,除尘器滤袋,除尘器骨架,电磁脉冲阀膜片,卸灰阀,螺旋输送机-泊头市天润环保机械设备有限公司 | 超细|超微气流粉碎机|气流磨|气流分级机|粉体改性机|磨粉机|粉碎设备-山东埃尔派粉体科技 | 恒温振荡混匀器-微孔板振荡器厂家-多管涡旋混匀器厂家-合肥艾本森(www.17world.net) | 环讯传媒,永康网络公司,永康网站建设,永康小程序开发制作,永康网站制作,武义网页设计,金华地区网站SEO优化推广 - 永康市环讯电子商务有限公司 | IP检测-检测您的IP质量| 北京银联移动POS机办理_收银POS机_智能pos机_刷卡机_收银系统_个人POS机-谷骐科技【官网】 | 上海律师事务所_上海刑事律师免费咨询平台-煊宏律师事务所 | 专注氟塑料泵_衬氟泵_磁力泵_卧龙泵阀_化工泵专业品牌 - 梭川泵阀 | 底部填充胶_电子封装胶_芯片封装胶_芯片底部填充胶厂家-东莞汉思新材料 | 强效碱性清洗剂-实验室中性清洗剂-食品级高纯氮气发生器-上海润榕科学器材有限公司 | 工业废水处理|污水处理厂|废水治理设备工程技术公司-苏州瑞美迪 今日娱乐圈——影视剧集_八卦娱乐_明星八卦_最新娱乐八卦新闻 | 商用绞肉机-熟肉切片机-冻肉切丁机-猪肉开条机 - 广州市正盈机械设备有限公司 | 机器视觉检测系统-视觉检测系统-机器视觉系统-ccd检测系统-视觉控制器-视控一体机 -海克易邦 | 选矿设备-新型重选设备-金属矿尾矿重选-青州冠诚重工机械有限公司 | 广州迈驰新GMP兽药包装机首页_药品包装机_中药散剂包装机 | 科普仪器菏泽市教育教学仪器总厂 | 智慧钢琴-电钢琴-便携钢琴-数码钢琴-深圳市特伦斯乐器有限公司 | 广东青藤环境科技有限公司-水质检测| 胶水,胶粘剂,AB胶,环氧胶,UV胶水,高温胶,快干胶,密封胶,结构胶,电子胶,厌氧胶,高温胶水,电子胶水-东莞聚力-聚厉胶粘 | 高低温万能试验机_拉力试验机_拉伸试验机-馥勒仪器科技(上海)有限公司 | 耐酸泵,耐腐蚀真空泵,耐酸真空泵-淄博华舜耐腐蚀真空泵有限公司 精密模具-双色注塑模具加工-深圳铭洋宇通 | 深圳市宏康仪器科技有限公司-模拟高空低压试验箱-高温防爆试验箱-温控短路试验箱【官网】 | 扬尘在线监测系统_工地噪声扬尘检测仪_扬尘监测系统_贝塔射线扬尘监测设备「风途物联网科技」 | 西门子伺服电机维修,西门子电源模块维修,西门子驱动模块维修-上海渠利 | 螺旋压榨机-刮泥机-潜水搅拌机-电动泥斗-潜水推流器-南京格林兰环保设备有限公司 | 石膏基自流平砂浆厂家-高强石膏基保温隔声自流平-轻质抹灰石膏粉砂浆批发-永康市汇利建设有限公司 | 半容积式换热器_北京浮动盘管换热器厂家|北京亿丰上达 | 申江储气罐厂家,储气罐批发价格,储气罐规格-上海申江压力容器有限公司(厂) | 彩信群发_群发彩信软件_视频短信营销平台-达信通 |