樂觀鎖與悲觀鎖领跛,都是人們定義出來的概念,可以說是一種思想撤奸。
樂觀鎖( Optimistic Locking ) 相對(duì)悲觀鎖而言吠昭,樂觀鎖機(jī)制采取了更加寬松的加鎖機(jī)制喊括。悲觀鎖大多數(shù)情況下依靠數(shù)據(jù)庫的鎖機(jī)制實(shí)現(xiàn),以保證操作最大程度的獨(dú)占性矢棚。但隨之而來的就是數(shù)據(jù)庫性能的大量開銷郑什,特別是對(duì)長(zhǎng)事務(wù)而言,這樣的開銷往往無法承受蒲肋。而樂觀鎖機(jī)制在一定程度上解決了這個(gè)問題蘑拯。樂觀鎖,大多是基于數(shù)據(jù)版本( Version )記錄機(jī)制實(shí)現(xiàn)兜粘。何謂數(shù)據(jù)版本申窘?即為數(shù)據(jù)增加一個(gè)版本標(biāo)識(shí),在基于數(shù)據(jù)庫表的版本解決方案中孔轴,一般是通過為數(shù)據(jù)庫表增加一個(gè) “version” 字段來實(shí)現(xiàn)剃法。讀取出數(shù)據(jù)時(shí),將此版本號(hào)一同讀出路鹰,之后更新時(shí)贷洲,對(duì)此版本號(hào)加一。此時(shí)晋柱,將提交數(shù)據(jù)的版本數(shù)據(jù)與數(shù)據(jù)庫表對(duì)應(yīng)記錄的當(dāng)前版本信息進(jìn)行比對(duì)优构,如果提交的數(shù)據(jù)版本號(hào)大于數(shù)據(jù)庫表當(dāng)前版本號(hào),則予以更新雁竞,否則認(rèn)為是過期數(shù)據(jù)俩块。
悲觀鎖(Pessimistic Lock),正如其名浓领,具有強(qiáng)烈的獨(dú)占和排他特性玉凯。它指的是對(duì)數(shù)據(jù)被外界(包括本系統(tǒng)當(dāng)前的其他事務(wù),以及來自外部系統(tǒng)的事務(wù)處理)修改持保守態(tài)度联贩,因此漫仆,在整個(gè)數(shù)據(jù)處理過程中,將數(shù)據(jù)處于鎖定狀態(tài)泪幌。悲觀鎖的實(shí)現(xiàn)盲厌,往往依靠數(shù)據(jù)庫提供的鎖機(jī)制(也只有數(shù)據(jù)庫層提供的鎖機(jī)制才能真正保證數(shù)據(jù)訪問的排他性,否則祸泪,即使在本系統(tǒng)中實(shí)現(xiàn)了加鎖機(jī)制吗浩,也無法保證外部系統(tǒng)不會(huì)修改數(shù)據(jù))。
優(yōu)點(diǎn)與不足
悲觀并發(fā)控制實(shí)際上是“先取鎖再訪問”的保守策略没隘,為數(shù)據(jù)處理的安全提供了保證懂扼。但是在效率方面,處理加鎖的機(jī)制會(huì)讓數(shù)據(jù)庫產(chǎn)生額外的開銷,還有增加產(chǎn)生死鎖的機(jī)會(huì)阀湿;另外赶熟,在只讀型事務(wù)處理中由于不會(huì)產(chǎn)生沖突,也沒必要使用鎖陷嘴,這樣做只能增加系統(tǒng)負(fù)載映砖;還有會(huì)降低了并行性次和,一個(gè)事務(wù)如果鎖定了某行數(shù)據(jù)凌那,其他事務(wù)就必須等待該事務(wù)處理完才可以處理那行數(shù)端考。(synchronized)
樂觀并發(fā)控制相信事務(wù)之間的數(shù)據(jù)競(jìng)爭(zhēng)(data race)的概率是比較小的径筏,因此盡可能直接做下去棍厌,直到提交的時(shí)候才去鎖定童本,所以不會(huì)產(chǎn)生任何鎖和死鎖嗤堰。但如果直接簡(jiǎn)單這么做冷溃,還是有可能會(huì)遇到不可預(yù)期的結(jié)果浴骂,例如兩個(gè)事務(wù)都讀取了數(shù)據(jù)庫的某一行乓土,經(jīng)過修改以后寫回?cái)?shù)據(jù)庫,這時(shí)就遇到了問題溯警。(CAS)
個(gè)人公號(hào):【排骨肉段】趣苏,可以關(guān)注一下。