悲觀鎖(Pessimistic Lock), 顧名思義,就是很悲觀,每次去拿數(shù)據(jù)的時候都認(rèn)為別人會修改,所以每次在拿數(shù)據(jù)的時候都會上鎖,這樣別人想拿這個數(shù)據(jù)就會block直到它拿到鎖欣喧。傳統(tǒng)的關(guān)系型數(shù)據(jù)庫里邊就用到了很多這種鎖機(jī)制,比如行鎖梯找,表鎖等唆阿,讀鎖,寫鎖等锈锤,都是在做操作之前先上鎖驯鳖。
樂觀鎖(Optimistic Lock), 顧名思義,就是很樂觀久免,每次去拿數(shù)據(jù)的時候都認(rèn)為別人不會修改浅辙,所以不會上鎖,但是在更新的時候會判斷一下在此期間別人有沒有去更新這個數(shù)據(jù)阎姥,可以使用版本號等機(jī)制记舆。樂觀鎖適用于多讀的應(yīng)用類型,這樣可以提高吞吐量呼巴,像數(shù)據(jù)庫如果提供類似于write_condition機(jī)制的其實(shí)都是提供的樂觀鎖泽腮。
兩種鎖各有優(yōu)缺點(diǎn)御蒲,不可認(rèn)為一種好于另一種,像樂觀鎖適用于寫比較少的情況下诊赊,即沖突真的很少發(fā)生的時候厚满,這樣可以省去了鎖的開銷,加大了系統(tǒng)的整個吞吐量豪筝。但如果經(jīng)常產(chǎn)生沖突痰滋,上層應(yīng)用會不斷的進(jìn)行retry摘能,這樣反倒是降低了性能续崖,所以這種情況下用悲觀鎖就比較合適。