悲觀鎖(Pessimistic Lock)
顧名思義,就是很悲觀,每次去拿資料的時候都認為別人會修改,所以每次在拿資料的時候都會上鎖,這樣別人想拿這個資料就會阻塞直到它拿到鎖。
傳統的關係型資料庫裡邊就用到了很多這種鎖機制,例如行鎖,表鎖等,讀鎖,寫鎖等,都是在做操作之前先上鎖。它指的是對資料被外界(包括本系統目前的其他事務,以及來自外部系統的事務處理)修改持保守態度,因此,在整個資料處理過程中,將資料處於鎖定狀態。
悲觀鎖定的實現,往往依靠資料庫提供的鎖定機制(也只有資料庫層提供的鎖定機制才能真正保證資料存取的排他性,否則,即使在本系統中實現了加鎖機制,也無法保證外部系統不會修改資料)。
樂觀鎖(Optimistic Lock)
#顧名思義,就是很樂觀,每次去拿資料的時候都認為別人不會修改,所以不會上鎖,但是在更新的時候會判斷一下在此期間別人有沒有去更新這個數據,可以使用版本號等機制。
樂觀鎖定適用於多讀取的應用類型,這樣可以提高吞吐量,像資料庫如果提供類似write_condition機制的其實都是提供的樂觀鎖。
總結
兩種鎖定各有優缺點,不可認為一種好於另一種,像樂觀鎖定適用於寫比較少的情況下,即衝突真的很少發生的時候,這樣可以省去了鎖的開銷,加大了系統的整個吞吐量。但如果經常產生衝突,上層應用會不斷的進行retry,這樣反倒是降低了性能,所以這種情況下用悲觀鎖就比較合適。
更多PHP相關知識,請造訪PHP中文網!
以上是php悲觀鎖和樂觀鎖的差別是什麼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!