鎖(Lock):
在介紹悲觀鎖和樂觀鎖之前,讓我們看一下鎖。鎖,在我們生活中隨處可見,我們的門上有鎖,我們存錢的保險柜上有鎖,是用來保護我們財產安全的。程序中也有鎖,當多個線程修改共享變量時,我們可以給修改操作上鎖(syncronized)。當多個用戶修改表中同一數據時,我們可以給該行數據上鎖(行鎖)。因此,鎖其實是在并發下控制多個操作的順序執行,以此來保證數據安全的變動。 并且,鎖是一種保證數據安全的機制和手段,而并不是特定于某項技術的。悲觀鎖和樂觀鎖亦是如此。
悲觀鎖(Pessimistic Lock)
顧名思義,就是很悲觀,每次去拿數據的時候都認為別人會修改,所以每次在拿數據的時候都會上鎖,這樣別人想拿這個數據就會block直到它拿到鎖。傳統的關系型數據庫里邊就用到了很多這種鎖機制,比如行鎖,表鎖等,讀鎖,寫鎖等,都是在做操作之前先上鎖。它指的是對數據被外界(包括本系統當前的其他事務,以及來自外部系統的事務處理)修改持保守態度,因此,在整個數據處理過程中,將數據處于鎖定狀態。悲觀鎖的實現,往往依靠數據庫提供的鎖機制(也只有數據庫層提供的鎖機制才能真正保證數據訪問的排他性,否則,即使在本系統中實現了加鎖機制,也無法保證外部系統不會修改數據)。