樂觀鎖悲觀鎖

樂觀鎖與悲觀鎖领跛,都是人們定義出來的概念,可以說是一種思想撤奸。

樂觀鎖( 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)注一下。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末梯轻,一起剝皮案震驚了整個(gè)濱河市食磕,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌喳挑,老刑警劉巖彬伦,帶你破解...
    沈念sama閱讀 218,036評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異伊诵,居然都是意外死亡单绑,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門曹宴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來搂橙,“玉大人,你說我怎么就攤上這事笛坦∏” “怎么了?”我有些...
    開封第一講書人閱讀 164,411評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵版扩,是天一觀的道長(zhǎng)废离。 經(jīng)常有香客問我,道長(zhǎng)礁芦,這世上最難降的妖魔是什么蜻韭? 我笑而不...
    開封第一講書人閱讀 58,622評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上湘捎,老公的妹妹穿的比我還像新娘诀豁。我一直安慰自己窄刘,他們只是感情好窥妇,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著娩践,像睡著了一般活翩。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上翻伺,一...
    開封第一講書人閱讀 51,521評(píng)論 1 304
  • 那天材泄,我揣著相機(jī)與錄音,去河邊找鬼吨岭。 笑死拉宗,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的辣辫。 我是一名探鬼主播旦事,決...
    沈念sama閱讀 40,288評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼急灭!你這毒婦竟也來了姐浮?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,200評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤葬馋,失蹤者是張志新(化名)和其女友劉穎卖鲤,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體畴嘶,經(jīng)...
    沈念sama閱讀 45,644評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蛋逾,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了窗悯。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片区匣。...
    茶點(diǎn)故事閱讀 39,953評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖蟀瞧,靈堂內(nèi)的尸體忽然破棺而出沉颂,到底是詐尸還是另有隱情,我是刑警寧澤悦污,帶...
    沈念sama閱讀 35,673評(píng)論 5 346
  • 正文 年R本政府宣布铸屉,位于F島的核電站,受9級(jí)特大地震影響切端,放射性物質(zhì)發(fā)生泄漏彻坛。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望昌屉。 院中可真熱鬧钙蒙,春花似錦、人聲如沸间驮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽竞帽。三九已至扛施,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間屹篓,已是汗流浹背疙渣。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留堆巧,地道東北人妄荔。 一個(gè)月前我還...
    沈念sama閱讀 48,119評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像谍肤,于是被迫代替她去往敵國(guó)和親啦租。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 數(shù)據(jù)庫管理系統(tǒng)(DBMS)中的并發(fā)控制的任務(wù)是確保在多個(gè)事務(wù)同時(shí)存取數(shù)據(jù)庫中同一數(shù)據(jù)時(shí)不破壞事務(wù)的隔離性和統(tǒng)一性以...
    出門變浪人閱讀 429評(píng)論 0 0
  • 并發(fā)控制 并發(fā)控制:當(dāng)多個(gè)連接對(duì)記錄進(jìn)行修改的時(shí)保證數(shù)據(jù)的一致性。 悲觀鎖乳附,樂觀鎖 確保在多個(gè)事務(wù)同時(shí)存取數(shù)據(jù)庫中...
    HikariCP閱讀 1,341評(píng)論 0 3
  • 悲觀鎖: 在讀取數(shù)據(jù)時(shí)鎖住那幾行赋除,其他對(duì)這幾行的更新需要等到悲觀鎖結(jié)束時(shí)才能繼續(xù) 樂觀鎖: 讀取數(shù)據(jù)時(shí)不鎖阱缓,更新時(shí)...
    光小月閱讀 328評(píng)論 0 0
  • 參考鏈接:http://blog.csdn.net/qwe6112071/article/details/5084...
    這是一個(gè)技術(shù)左閱讀 969評(píng)論 0 0
  • 下午一輛現(xiàn)代名圖清洗空調(diào)颁糟,完事又要貼膜航背,整完以后開回來等待客戶取車,客戶打電話過來棱貌,說有點(diǎn)遠(yuǎn)玖媚,讓過去接他,告訴他沒...
    88e94d537f85閱讀 134評(píng)論 0 0