<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

        關(guān)于Mysql隔離級(jí)別、鎖與MVCC介紹

        來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-09 20:28:23
        文檔

        關(guān)于Mysql隔離級(jí)別、鎖與MVCC介紹

        關(guān)于Mysql隔離級(jí)別、鎖與MVCC介紹:本文意在弄清楚這些概念間的關(guān)系及其作用。弄清Mysql在開啟事務(wù)的情況下,每條sql執(zhí)行時(shí)的加鎖操作和MVCC版本控制。為使討論簡單,本文忽略了GAP鎖(間隙鎖、范圍鎖)。 我們經(jīng)常所高并發(fā),高可用。就是從質(zhì)和量來評(píng)估,任何事物都可以從這兩個(gè)角度來分析。在
        推薦度:
        導(dǎo)讀關(guān)于Mysql隔離級(jí)別、鎖與MVCC介紹:本文意在弄清楚這些概念間的關(guān)系及其作用。弄清Mysql在開啟事務(wù)的情況下,每條sql執(zhí)行時(shí)的加鎖操作和MVCC版本控制。為使討論簡單,本文忽略了GAP鎖(間隙鎖、范圍鎖)。 我們經(jīng)常所高并發(fā),高可用。就是從質(zhì)和量來評(píng)估,任何事物都可以從這兩個(gè)角度來分析。在

        本文意在弄清楚這些概念間的關(guān)系及其作用。弄清Mysql在開啟事務(wù)的情況下,每條sql執(zhí)行時(shí)的加鎖操作和MVCC版本控制。為使討論簡單,本文忽略了GAP鎖(間隙鎖、范圍鎖)。

        我們經(jīng)常所高并發(fā),高可用。就是從質(zhì)和量來評(píng)估,任何事物都可以從這兩個(gè)角度來分析。在Mysql數(shù)據(jù)庫中,事務(wù)就是用來保證質(zhì)的,MVCC就是用來保證量的。

        事務(wù)

        我們使用事務(wù)來保證每一條SQL語句的結(jié)果執(zhí)行符合我們的預(yù)期。我們說事務(wù)必須具備ACID特性。ACID中的三者:原子性、一致性和持久性其實(shí)描述的都差不多,保證SQL執(zhí)行結(jié)果的可靠性。而隔離性就比較復(fù)雜了,隔離性描述的是在并發(fā)場景下數(shù)據(jù)庫的表現(xiàn),但并發(fā)量并不是固定的,而不同的業(yè)務(wù)可能有不同的需求,為了使數(shù)據(jù)庫能適應(yīng)不同的并發(fā)場景,所以偉大的人們又定義了四種隔離級(jí)別:Read Uncommited,Read Committed (RC),Repeatable Read (RR),Serializable。隨著數(shù)據(jù)庫隔離級(jí)別的提高,數(shù)據(jù)的并發(fā)能力也有所下降。

        隔離級(jí)別

        標(biāo)準(zhǔn)隔離級(jí)別下數(shù)據(jù)庫會(huì)怎么表現(xiàn)可參考//www.gxlcms.com/article/116477.htm,我們這里只討論共享鎖和排它鎖這兩概念,讀加共享鎖,寫加排它鎖:

        在RC隔離級(jí)別下,修改數(shù)據(jù)會(huì)加排它鎖,事務(wù)結(jié)束釋放,其他事務(wù)不許讀,解決臟讀問題。(共享鎖當(dāng)場釋放)
        在RR隔離級(jí)別下,讀數(shù)據(jù)加共享鎖,事務(wù)結(jié)束釋放,其他事務(wù)不許修改,解決不可重復(fù)讀。(共享鎖事務(wù)結(jié)束釋放)

        實(shí)際上都把操作串行化了。而Mysql對(duì)其進(jìn)行了優(yōu)化,一個(gè)事務(wù)讀時(shí)其他事務(wù)不能寫,一個(gè)事務(wù)寫時(shí)其他事務(wù)不能讀?我不這么干照樣能解決臟讀和不可重復(fù)讀問題。MVCC出現(xiàn)了。(這也使得問題變得越來越復(fù)雜,而不一樣的地方也開始出現(xiàn)在RR隔離級(jí)別下,碰巧Mysql的默認(rèn)隔離級(jí)別就是RR)

        MVCC

        MVCC即多版本并發(fā)控制,使用了雙版本號(hào)來解決數(shù)據(jù)的隔離問題。(“create”一個(gè)版本號(hào),“delete”一個(gè)版本號(hào),修改操作拆分為“delete”和“create”)每個(gè)事務(wù)在開始對(duì)每張表增刪改查操作時(shí)都會(huì)生成一個(gè)版本號(hào),每個(gè)事務(wù)只能查到“create”小于本版本號(hào)和“delete”大于本版本號(hào)的數(shù)據(jù)。這樣,增刪查操作就完全可以并發(fā)進(jìn)行了,只有修改操作是一定要排隊(duì)的。這樣,就算沒有共享鎖也解決了不可重復(fù)讀問題,因?yàn)槠渌聞?wù)修改后,數(shù)據(jù)的版本號(hào)比我大,我不會(huì)讀到。

        MVCC在RR隔離級(jí)別下的并發(fā)

        引入MVCC之后,看似很美好。然而大家有沒有想過兩個(gè)事務(wù)先后對(duì)一條數(shù)據(jù)做更新操作,然后兩個(gè)事務(wù)再讀取那條數(shù)據(jù),分別讀到什么?哈哈,這根本是不可能出現(xiàn)的,因?yàn)樾薷牟僮魇谴械模硪粋€(gè)事務(wù)必須先commit本事務(wù)才能修改。好,換個(gè)問題,兩個(gè)事務(wù)先后對(duì)一條數(shù)據(jù)做+1操作,另一個(gè)事務(wù)提交后,本事務(wù)再+1,再讀取那條數(shù)據(jù),本事務(wù)是讀取到+1還是+2的結(jié)果?如果讀取到+2,那不是破壞了隔離性,讀到了其他事務(wù)提交的數(shù)據(jù)么?

        然而事實(shí)確實(shí)是這樣,其他事務(wù)已經(jīng)提交,本事務(wù)也已修改過那條數(shù)據(jù)了,之后當(dāng)然要讀到+2才行。雖然本來是0,本事務(wù)明明只加了1,可讀取后卻變成2了,有點(diǎn)不適應(yīng)。確實(shí),在標(biāo)準(zhǔn)的RR隔離級(jí)別下,因?yàn)椴僮鞫际谴械模臼聞?wù)讀取一行數(shù)據(jù)后,其他事務(wù)就不能修改這條數(shù)據(jù)了,這條數(shù)據(jù)永遠(yuǎn)只有本事務(wù)在操作,所以嚴(yán)格滿足隔離性。但是Mysql的RR增強(qiáng)了讀與寫的并發(fā),只有當(dāng)兩個(gè)事務(wù)同時(shí)修改一條數(shù)據(jù)需要串行,其他所有操作都可以并行。所以造成了這種結(jié)果,好像出現(xiàn)了不可重復(fù)讀。但是這種不可重復(fù)讀實(shí)際上是符合我們的直觀感受的,在本事務(wù)對(duì)數(shù)據(jù)修改后,當(dāng)然要讀取到最新的數(shù)據(jù)。

        要對(duì)其過程進(jìn)行分析的話:

        數(shù)據(jù)create版本號(hào)為0

        事務(wù)1版本號(hào)為1,讀取數(shù)據(jù)value=0

        事務(wù)2版本號(hào)為2,修改數(shù)據(jù)value+1=1,原數(shù)據(jù)delete版本號(hào)為2,新數(shù)據(jù)create版本號(hào)更新為2,commit

        事務(wù)1修改數(shù)據(jù)value+1=2,(由于修改是當(dāng)前讀,永遠(yuǎn)讀取版本號(hào)最大的數(shù)據(jù),所以讀取到value為1)修改后delete版本號(hào)為1,

        新數(shù)據(jù)create版本號(hào)為1

        本事務(wù)讀取數(shù)據(jù)value=2

        深入分析:

        其實(shí)上面的描述也是有漏洞的,如果有第三個(gè)事務(wù)版本號(hào)為3呢?因?yàn)榘姹咎?hào)為3,是不是可以直接讀取事務(wù)1、2未提交的數(shù)據(jù)?實(shí)際上在MVCC中,每個(gè)事務(wù)還有一個(gè)最低可見版本low_limit_id(事務(wù)號(hào) >= low_limit_id的記錄,對(duì)于當(dāng)前事務(wù)都是不可見的),把當(dāng)前正在執(zhí)行還沒commit的事務(wù)給過濾掉了。例如事務(wù)3,雖然版本號(hào)為3,但是low_limit_id=1,所以事務(wù)1和事務(wù)2的修改對(duì)3都是不可見的。

        總結(jié)

        為了解決隔離性問題,都沒有使用完全copy數(shù)據(jù)這種笨方法。傳統(tǒng)數(shù)據(jù)庫使用共享鎖和排它鎖使讀寫操作串行;Mysql使用MVCC和排它鎖,讀寫可并行。Mysql在RR隔離級(jí)別以下,和傳統(tǒng)方式表現(xiàn)一致,在RR隔離級(jí)別,和傳統(tǒng)方式有差異,體現(xiàn)在本事務(wù)更新某條數(shù)據(jù)后,能讀取到其他事務(wù)對(duì)該條數(shù)據(jù)已提交的修改。

        聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        關(guān)于Mysql隔離級(jí)別、鎖與MVCC介紹

        關(guān)于Mysql隔離級(jí)別、鎖與MVCC介紹:本文意在弄清楚這些概念間的關(guān)系及其作用。弄清Mysql在開啟事務(wù)的情況下,每條sql執(zhí)行時(shí)的加鎖操作和MVCC版本控制。為使討論簡單,本文忽略了GAP鎖(間隙鎖、范圍鎖)。 我們經(jīng)常所高并發(fā),高可用。就是從質(zhì)和量來評(píng)估,任何事物都可以從這兩個(gè)角度來分析。在
        推薦度:
        標(biāo)簽: mysql MVCC 隔離級(jí)別
        • 熱門焦點(diǎn)

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 免费看美女午夜大片| 亚洲另类无码一区二区三区| 本道天堂成在人线av无码免费| 免费羞羞视频网站| 亚洲国产精品无码久久久秋霞1| 噜噜嘿在线视频免费观看| 亚洲国产精品ⅴa在线观看| 免费鲁丝片一级观看| 色综合久久精品亚洲国产| 亚洲国产精品成人| 特级毛片爽www免费版| 亚洲午夜福利在线观看| 免费精品99久久国产综合精品| 亚洲国产精品无码专区在线观看| 国产成人精品无码免费看| 亚洲Av无码精品色午夜| 日本免费人成在线网站| 亚洲国产视频久久| 亚洲JIZZJIZZ中国少妇中文| 成人无码视频97免费| 亚洲视频免费在线播放| 毛片a级毛片免费观看免下载| 亚洲精品无码永久在线观看男男 | 人人玩人人添人人澡免费| 久久久亚洲欧洲日产国码是AV| 国产情侣激情在线视频免费看| 亚洲中文字幕久久精品蜜桃| 全部免费a级毛片| 一个人免费视频在线观看www| 亚洲最大黄色网站| 免费在线精品视频| 最近免费中文字幕高清大全| 亚洲人成网站免费播放| 激情97综合亚洲色婷婷五| 精品久久久久久久久免费影院| 亚洲风情亚Aⅴ在线发布| 久久久久亚洲精品成人网小说| 日本精品人妻无码免费大全| 中文字幕在线免费观看视频| 亚洲二区在线视频| 中文字幕无码精品亚洲资源网|