首頁 >後端開發 >php教程 >php樂觀鎖原理詳解

php樂觀鎖原理詳解

小云云
小云云原創
2018-03-08 09:21:542879瀏覽

一、為什麼需要鎖(並發控制)?

      在多重使用者環境中,在同一時間可能會有多個使用者更新相同的記錄,這會產生衝突。這就是著名的並發性問題。
      典型的衝突有:
        1.遺失更新:一個事務的更新涵蓋了其它事務的更新結果,就是所謂的更新遺失。例如:用戶A把值從6改為2,用戶B把值從2改為6,則用戶A丟失了他的更新。
        2.髒讀:當一個事務讀取其它完成一半事務的記錄時,就會發生髒讀取。例如:用戶A,B看到的值都是6,用戶B把值改為2,用戶A讀到的值仍是6。

       為了解決這些同時所帶來的問題。 我們需要引入並發控制機制。

二、 並發控制機制

             鎖定,即給我們選取的目標資料上鎖定,使其無法被其他程式修改。

            1.悲觀鎖定:指的是對資料被外部(包括本系統目前的其他事務,以及外部系統的事務處理)修改持保守態度,因此,在整個資料處理過程中,將資料處於鎖定狀態
            2.樂觀鎖定:假設不會發生同時衝突,且只在提交作業時檢查是否違反資料完整性。樂觀鎖不能解決髒讀的問題。

三、樂觀鎖定的實現
        使用資料版本(Version)記錄機制實現,這是樂觀鎖定最常用的實現方式。何謂數據版本?即為資料增加一個版本標識,一般是透過為資料庫表增加一個數字類型的 “version” 字段來實現。當讀取資料時,將version欄位的值一同讀出,資料每更新一次,對此version值加一。當我們提交更新的時候,判斷資料庫表對應記錄的當前版本資訊與第一次取出的version值進行比對,如果資料庫表目前版本號與第一次取出的version值相等,則予以更新,否則認為是過期資料

   1.資料庫表格設計

     task

   有三個字段,分別為id,value、version

#2.實作

   1)先讀task表的資料(實際上這個表只有一筆記錄),得到version的值為versionValue

   2)每次更新task表中的value欄位時,為了防止發生衝突,需要這樣動作

      update task set value = newValue,version =  versionValue + 1   where version = versionValue;

##    cvalue 語句執行了,才表明本次更新值成功

    如假設有兩個節點A和B都要更新task表中的value字段值,差不多在同一時刻,A節點和B節點從task表中讀到的version值為2,那麼A節點和B節點在更新value字段值的時候,都操作 update task set value = newValue,version =  3   where version = 2;,實際上只有1個節點執行該SQL語句成功,假設A節點執行成功,那麼此時task表的version欄位的值是3,B節點再操作update task set value = newValue,version =  3   where version = 2;這條SQL語句是不執行的,這樣就保證了更新task表時不發生衝突。

相關推薦:

Yii2.0樂觀鎖定與悲觀鎖定實例詳解

實作redis中事務機制及樂觀鎖定的方法

資料庫事物樂觀鎖定與悲觀鎖定

以上是php樂觀鎖原理詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn