悲觀鎖與樂(lè)觀鎖的區(qū)別

悲觀鎖(Pessimistic Lock), 顧名思義,就是很悲觀,每次去拿數(shù)據(jù)的時(shí)候都認(rèn)為別人會(huì)修改,所以每次在拿數(shù)據(jù)的時(shí)候都會(huì)上鎖,這樣別人想拿這個(gè)數(shù)據(jù)就會(huì)block直到它拿到鎖。傳統(tǒng)的關(guān)系型數(shù)據(jù)庫(kù)里邊就用到了很多這種鎖機(jī)制,比如行鎖,表鎖等,讀鎖,寫(xiě)鎖等,都是在做操作之前先上鎖。

樂(lè)觀鎖(Optimistic Lock), 顧名思義,就是很樂(lè)觀,每次去拿數(shù)據(jù)的時(shí)候都認(rèn)為別人不會(huì)修改,所以不會(huì)上鎖,但是在更新的時(shí)候會(huì)判斷一下在此期間別人有沒(méi)有去更新這個(gè)數(shù)據(jù),可以使用版本號(hào)等機(jī)制。樂(lè)觀鎖適用于多讀的應(yīng)用類(lèi)型,這樣可以提高吞吐量,像數(shù)據(jù)庫(kù)如果提供類(lèi)似于write_condition機(jī)制的其實(shí)都是提供的樂(lè)觀鎖。

兩種鎖各有優(yōu)缺點(diǎn),不可認(rèn)為一種好于另一種,像樂(lè)觀鎖適用于寫(xiě)比較少的情況下,即沖突真的很少發(fā)生的時(shí)候,這樣可以省去了鎖的開(kāi)銷(xiāo),加大了系統(tǒng)的整個(gè)吞吐量。但如果經(jīng)常產(chǎn)生沖突,上層應(yīng)用會(huì)不斷的進(jìn)行retry,這樣反倒是降低了性能,所以這種情況下用悲觀鎖就比較合適。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 一分鐘教你知道樂(lè)觀鎖和悲觀鎖的區(qū)別 悲觀鎖(Pessimistic Lock), 顧名思義,就是很悲觀,每次去拿數(shù)...
    php紅薯閱讀 4,644評(píng)論 2 58
  • 本質(zhì): 悲觀鎖和樂(lè)觀鎖都是一種概念和認(rèn)知。數(shù)據(jù)庫(kù)有java語(yǔ)言都有對(duì)應(yīng)的實(shí)現(xiàn)方式。 悲觀鎖 悲觀鎖(Pessimi...
    極簡(jiǎn)架構(gòu)閱讀 887評(píng)論 0 3
  • 悲觀鎖 悲觀鎖(Pessimistic Lock),顧名思義,就是很悲觀,每次去拿數(shù)據(jù)的時(shí)候都認(rèn)為別人會(huì)修改,所以...
    FX_SKY閱讀 70,793評(píng)論 18 106
  • 悲觀鎖(Pessimistic Lock), 顧名思義,就是很悲觀,每次去拿數(shù)據(jù)的時(shí)候都認(rèn)為別人會(huì)修改,所以每次在...
    yljava閱讀 8,147評(píng)論 0 0
  • 這時(shí),百合雨走了過(guò)來(lái)??吹嚼溷懸繇嵞樕n白,跪倒在地,關(guān)心的問(wèn):"音,你怎么了?""雨,雨。你…看?。⒗溷懸繇嵵钢?..
    奈琳索百晗閱讀 242評(píng)論 0 0

友情鏈接更多精彩內(nèi)容