mysql鎖機制

mysql鎖機制深層而又復雜,而且針對不對的存儲引擎鎖實現(xiàn)的方式以及表現(xiàn)形式又不一樣陈惰,本文只針對mysql?InnoDB行鎖實現(xiàn)方式 進行整理本文純屬掃盲級別,大神請忽略··

先說一些數(shù)據(jù)庫事務的背景知識:

事務的ACID原則

事務是由一組SQL語句組成的邏輯處理單元,事務具有以下4個屬性官份,通常簡稱為事務的ACID屬性缴罗。

? ? ? ?原子性(Atomicity):事務是一個原子操作單元助琐,其對數(shù)據(jù)的修改,要么全都執(zhí)行瞒爬,要么全都不執(zhí)行弓柱。

? ? 一致性(Consistent):在事務開始和完成時,數(shù)據(jù)都必須保持一致狀態(tài)侧但。這意味著所有相關的數(shù)據(jù)規(guī)則都必須應用于事務的修改矢空,以保持數(shù)據(jù)的完整性;事務結束時禀横,所有的內部數(shù)據(jù)結構(如B樹索引或雙向鏈表)也都必須是正確的屁药。

? ? ? ? 隔離性(Isolation):數(shù)據(jù)庫系統(tǒng)提供一定的隔離機制,保證事務在不受外部并發(fā)操作影響的“獨立”環(huán)境執(zhí)行柏锄。這意味著事務處理過程中的中間狀態(tài)對外部是不可見的酿箭,反之亦然。 ? ? ? ? 持久性(Durable):事務完成之后趾娃,它對于數(shù)據(jù)的修改是永久性的缭嫡,即使出現(xiàn)系統(tǒng)故障也能夠保持。

銀行轉帳就是事務的一個典型例子

2.并發(fā)事務處理帶來的問題

相對于串行處理來說抬闷,并發(fā)事務處理能大大增加數(shù)據(jù)庫資源的利用率妇蛀,提高數(shù)據(jù)庫系統(tǒng)的事務吞吐量,從而可以支持更多的用戶笤成。但并發(fā)事務處理也會帶來一些問題评架,主要包括以下幾種情況

l? 更新丟失(Lost Update):當兩個或多個事務選擇同一行炕泳,然后基于最初選定的值更新該行時纵诞,由于每個事務都不知道其他事務的存在,就會發(fā)生丟失更新問題--最后的更新覆蓋了由其他事務所做的更新培遵。例如浙芙,兩個編輯人員制作了同一文檔的電子副本登刺。每個編輯人員獨立地更改其副本,然后保存更改后的副本茁裙,這樣就覆蓋了原始文檔塘砸。最后保存其更改副本的編輯人員覆蓋另一個編輯人員所做的更改。如果在一個編輯人員完成并提交事務之前晤锥,另一個編輯人員不能訪問同一文件掉蔬,則可避免此問題。

l? 臟讀(Dirty Reads):一個事務正在對一條記錄做修改矾瘾,在這個事務完成并提交前女轿,這條記錄的數(shù)據(jù)就處于不一致狀態(tài);這時壕翩,另一個事務也來讀取同一條記錄蛉迹,如果不加控制,第二個事務讀取了這些“臟”數(shù)據(jù)放妈,并據(jù)此做進一步的處理北救,就會產(chǎn)生未提交的數(shù)據(jù)依賴關系。這種現(xiàn)象被形象地叫做"臟讀"芜抒。

l? 不可重復讀(Non-Repeatable Reads):一個事務在讀取某些數(shù)據(jù)后的某個時間珍策,再次讀取以前讀過的數(shù)據(jù),卻發(fā)現(xiàn)其讀出的數(shù)據(jù)已經(jīng)發(fā)生了改變宅倒、或某些記錄已經(jīng)被刪除了攘宙!這種現(xiàn)象就叫做“不可重復讀”。

l? 幻讀(Phantom Reads):一個事務按相同的查詢條件重新讀取以前檢索過的數(shù)據(jù)拐迁,卻發(fā)現(xiàn)其他事務插入了滿足其查詢條件的新數(shù)據(jù)蹭劈,這種現(xiàn)象就稱為“幻讀”。

3.事務隔離級別

在上面講到的并發(fā)事務處理帶來的問題中线召,“更新丟失”通常是應該完全避免的铺韧。但防止更新丟失,并不能單靠數(shù)據(jù)庫事務控制器來解決缓淹,需要應用程序對要更新的數(shù)據(jù)加必要的鎖來解決祟蚀,因此,防止更新丟失應該是應用的責任割卖。

“臟讀”、“不可重復讀”和“幻讀”患雏,其實都是數(shù)據(jù)庫讀一致性問題鹏溯,必須由數(shù)據(jù)庫提供一定的事務隔離機制來解決。數(shù)據(jù)庫實現(xiàn)事務隔離的方式淹仑,基本上可分為以下兩種丙挽。

l? 一種是在讀取數(shù)據(jù)前肺孵,對其加鎖,阻止其他事務對數(shù)據(jù)進行修改颜阐。

l? 另一種是不用加任何鎖平窘,通過一定機制生成一個數(shù)據(jù)請求時間點的一致性數(shù)據(jù)快照(Snapshot),并用這個快照來提供一定級別(語句級或事務級)的一致性讀取凳怨。從用戶的角度來看瑰艘,好像是數(shù)據(jù)庫可以提供同一數(shù)據(jù)的多個版本,因此肤舞,這種技術叫做數(shù)據(jù)多版本并發(fā)控制(MultiVersion Concurrency Control紫新,簡稱MVCC或MCC),也經(jīng)常稱為多版本數(shù)據(jù)庫李剖。

數(shù)據(jù)庫的事務隔離越嚴格芒率,并發(fā)副作用越小,但付出的代價也就越大篙顺,因為事務隔離實質上就是使事務在一定程度上 “串行化”進行偶芍,這顯然與“并發(fā)”是矛盾的。同時德玫,不同的應用對讀一致性和事務隔離程度的要求也是不同的匪蟀,比如許多應用對“不可重復讀”和“幻讀”并不敏感,可能更關心數(shù)據(jù)并發(fā)訪問的能力化焕。

讀數(shù)據(jù)一致性及允許的并發(fā)副作用

InnoDB的行鎖模式及加鎖方法

InnoDB實現(xiàn)了以下兩種類型的行鎖萄窜。

l? 共享鎖(S):允許一個事務去讀一行,阻止其他事務獲得相同數(shù)據(jù)集的排他鎖撒桨。

l? 排他鎖(X):允許獲得排他鎖的事務更新數(shù)據(jù)查刻,阻止其他事務取得相同數(shù)據(jù)集的共享讀鎖和排他寫鎖

對于UPDATE、DELETE和INSERT語句凤类,InnoDB會自動給涉及數(shù)據(jù)集加排他鎖(X)穗泵;對于普通SELECT語句,InnoDB不會加任何鎖谜疤;事務可以通過以下語句顯示給記錄集加共享鎖或排他鎖佃延。

?? 共享鎖(S):SELECT * FROM table_name WHERE ... LOCK IN SHARE MODE。

?? 排他鎖(X):SELECT * FROM table_name WHERE ... FOR UPDATE夷磕。

注意:如果SELECT語句使用了共享鎖 在當前事務下在使用排它鎖 在并發(fā)場景下會很容易出現(xiàn)死鎖

解決辦法:對于鎖定行記錄后需要進行更新操作的應用履肃,應該使用SELECT... FOR UPDATE方式獲得排他鎖。(記鬃:特別重要3咂濉!C圊巍1烀3筛!!荆残!在項目中遇到過的E!D谒埂蕴潦!)

InnoDB行鎖實現(xiàn)方式

InnoDB行鎖是通過給索引上的索引項加鎖來實現(xiàn)的,這一點MySQL與Oracle不同嘿期,后者是通過在數(shù)據(jù)塊中對相應數(shù)據(jù)行加鎖來實現(xiàn)的品擎。InnoDB這種行鎖實現(xiàn)特點意味著:只有通過索引條件檢索數(shù)據(jù),InnoDB才使用行級鎖备徐,否則萄传,InnoDB將使用表鎖!(記酌刍:特別重要P懔狻!2渌Q芰狻!<缁怼脊串!)

在實際應用中,要特別注意InnoDB行鎖的這一特性清钥,不然的話琼锋,可能導致大量的鎖沖突,從而影響并發(fā)性能(記姿钫选:特別重要B瓶病!4畚颉C仗尽!0嵩帷荷腊!)

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市急凰,隨后出現(xiàn)的幾起案子停局,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,348評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件董栽,死亡現(xiàn)場離奇詭異,居然都是意外死亡企孩,警方通過查閱死者的電腦和手機锭碳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,122評論 2 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來勿璃,“玉大人擒抛,你說我怎么就攤上這事〔挂桑” “怎么了歧沪?”我有些...
    開封第一講書人閱讀 156,936評論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長莲组。 經(jīng)常有香客問我诊胞,道長,這世上最難降的妖魔是什么锹杈? 我笑而不...
    開封第一講書人閱讀 56,427評論 1 283
  • 正文 為了忘掉前任撵孤,我火速辦了婚禮,結果婚禮上竭望,老公的妹妹穿的比我還像新娘邪码。我一直安慰自己,他們只是感情好咬清,可當我...
    茶點故事閱讀 65,467評論 6 385
  • 文/花漫 我一把揭開白布闭专。 她就那樣靜靜地躺著,像睡著了一般旧烧。 火紅的嫁衣襯著肌膚如雪影钉。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,785評論 1 290
  • 那天粪滤,我揣著相機與錄音斧拍,去河邊找鬼。 笑死杖小,一個胖子當著我的面吹牛肆汹,可吹牛的內容都是我干的。 我是一名探鬼主播予权,決...
    沈念sama閱讀 38,931評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼昂勉,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了扫腺?” 一聲冷哼從身側響起岗照,我...
    開封第一講書人閱讀 37,696評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后攒至,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體厚者,經(jīng)...
    沈念sama閱讀 44,141評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,483評論 2 327
  • 正文 我和宋清朗相戀三年迫吐,在試婚紗的時候發(fā)現(xiàn)自己被綠了库菲。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,625評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡志膀,死狀恐怖熙宇,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情溉浙,我是刑警寧澤烫止,帶...
    沈念sama閱讀 34,291評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站戳稽,受9級特大地震影響馆蠕,放射性物質發(fā)生泄漏。R本人自食惡果不足惜广鳍,卻給世界環(huán)境...
    茶點故事閱讀 39,892評論 3 312
  • 文/蒙蒙 一荆几、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧赊时,春花似錦吨铸、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至竭缝,卻和暖如春房维,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背抬纸。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工咙俩, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人湿故。 一個月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓阿趁,卻偏偏與公主長得像,于是被迫代替她去往敵國和親坛猪。 傳聞我的和親對象是個殘疾皇子脖阵,可洞房花燭夜當晚...
    茶點故事閱讀 43,492評論 2 348

推薦閱讀更多精彩內容

  • 概述 數(shù)據(jù)庫鎖定機制簡單來說,就是數(shù)據(jù)庫為了保證數(shù)據(jù)的一致性墅茉,而使各種共享資源在被并發(fā)訪問變得有序所設計的一種規(guī)則...
    datazhen閱讀 755評論 0 2
  • 悲觀鎖與樂觀鎖: 悲觀鎖:顧名思義命黔,就是很悲觀呜呐,每次去拿數(shù)據(jù)的時候都認為別人會修改,所以每次在拿數(shù)據(jù)的時候都會上鎖...
    像敏銳的狗閱讀 269評論 0 0
  • MYSQL 鎖機制 數(shù)據(jù)庫在對資源進行高并發(fā)的讀寫操作時悍募,為了保證數(shù)據(jù)的一致性蘑辑,有效性,鎖是很重要的機制坠宴。Mysq...
    莫Y兮閱讀 7,580評論 2 13
  • 行鎖以躯、表鎖對比 開銷、加鎖速度啄踊、死鎖、粒度刁标、并發(fā)性能 表鎖:開銷小颠通,加鎖快;不會出現(xiàn)死鎖膀懈;鎖定力度大顿锰,發(fā)生鎖沖突概...
    高廣超閱讀 6,160評論 0 25
  • 當一個系統(tǒng)訪問量上來的時候胳赌,不只是數(shù)據(jù)庫性能瓶頸問題了牢撼,數(shù)據(jù)庫數(shù)據(jù)安全也會浮現(xiàn),這時候合理使用數(shù)據(jù)庫鎖機制就顯得異...
    JackFrost_fuzhu閱讀 7,724評論 4 83