




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
并發控制第8章概述封鎖封鎖協議活鎖和死鎖并發調度的可串行性兩段鎖協議
封鎖的粒度
Oracle的并發控制1數據不一致的情況及其確切含義;封鎖的類型;不同封鎖類型的性質和定義;封鎖協議的概念;封鎖粒度的概念;多粒度封鎖方法及多粒度封鎖協議的相容控制矩陣。學習重點
學習難點第8章重點與難點
兩段鎖協議與串行性的關系;兩段鎖協議與死鎖的關系;具有意向鎖的多粒度封鎖方法的封鎖過程。2多事務執行方式(1)事務串行執行每個時刻只有一個事務運行不能充分利用系統資源,發揮數據庫共享資源的特點。(2)交叉并發方式(interleavedconcurrency)事務的并行執行是這些并行事務的并行操作輪流交叉運行單處理機系統中的并發方式,能夠減少處理機的空閑時間,提高系統的效率。(3)同時并發方式(simultaneousconcurrency)多處理機系統中,每個處理機可以運行一個事務,多個處理機可以同時運行多個事務,實現多個事務真正的并行運行。最理想的并發方式更復雜的并發方式機制概述3事務并發執行帶來的問題可能會存取和存儲不正確的數據,破壞事務的隔離性和數據庫的一致性。DBMS必須提供并發控制機制并發控制機制是衡量一個DBMS性能的重要標志之一。48.1并發控制概述并發控制機制的任務對并發操作進行正確調度保證事務的隔離性保證數據庫的一致性5數據不一致實例:飛機訂票系統
讀A=16
A←A-3寫回A=13①讀A=16
②
③A←A-1寫回A=15
④事務T2事務T1T1的修改被T2覆蓋了!6并發操作帶來的數據不一致性丟失修改(lostupdate)不可重復讀(non-repeatableread)讀“臟”數據(dirtyread)丟失修改是指事務1與事務2從數據庫中讀入同一數據并修改,事務2的提交結果破壞了事務1提交的結果,導致事務1的修改被丟失。不可重復讀是指事務1讀取數據后,事務2執行更新操作,使事務1無法再現前一次讀取結果。事務1修改某一數據,并將其寫回磁盤;事務2讀取同一數據后;事務1由于某種原因被撤消,這時事務1已修改過的數據恢復原值;事務2讀到的數據就與數據庫中的數據不一致,是不正確的數據,又稱為“臟”數據。7T1T2①讀A=16
②
③A←A-1寫回A=15
④
讀A=16
A←A-1寫回A=15(a)丟失修改
讀C=200
①讀C=100C←C*2寫回C②
③ROLLBACKC恢復為100T2T1(c)讀“臟”數據
讀B=100B←B*2寫回B=200
①讀A=50讀B=100求和=150②
③讀A=50讀B=200求和=250(驗算不對)T2T1(b)不可重復讀88.2封鎖(Locking)什么是封鎖基本封鎖類型基本鎖的相容矩陣9封鎖的概念封鎖就是事務T在對某個數據對象(例如表、記錄等)操作之前,先向系統發出請求,對其加鎖。加鎖后事務T就對該數據對象有了一定的控制,在事務T釋放它的鎖之前,其它的事務不能更新此數據對象。封鎖是實現并發控制的一個非常重要的技術。10基本封鎖類型DBMS通常提供了多種類型的封鎖。一個事務對某個數據對象加鎖后究竟擁有什么樣的控制是由封鎖的類型決定的。基本封鎖類型排它鎖(Exclusivelock,簡記為X鎖)共享鎖(Sharelock,簡記為S鎖)若事務T對數據對象A加上X鎖,則只允許T讀取和修改A,其它任何事務都不能再對A加任何類型的鎖,直到T釋放A上的鎖。若事務T對數據對象A加上S鎖,則其它事務只能再對A加S鎖,而不能加X鎖,直到T釋放A上的S鎖。11鎖的相容矩陣Y=Yes,相容的請求N=No,不相容的請求T1T2XS-XNNYSNYY-YYY128.3封鎖協議在運用X鎖和S鎖對數據對象加鎖時,需要約定一些規則:封鎖協議(LockingProtocol)
何時申請X鎖或S鎖持鎖時間、何時釋放不同的封鎖協議,在不同的程度上為并發操作的正確調度提供一定的保證常用的封鎖協議:三級封鎖協議131級封鎖協議事務T在修改數據R之前必須先對其加X鎖,直到事務結束才釋放正常結束(COMMIT)非正常結束(ROLLBACK)1級封鎖協議可防止丟失修改在1級封鎖協議中,如果是讀數據,不需要加鎖的,所以它不能保證可重復讀和不讀“臟”數據。14T1T2①
XlockA獲得②
讀A=16
③A←A-1寫回A=15CommitUnlockA④
⑤
XlockA等待等待等待等待獲得XlockA讀A=15A←A-1寫回A=14CommitUnlockA
沒有丟失修改
讀A=15①
XlockA獲得②
讀A=16
A←A-1寫回A=15③
④RollbackUnlockA
T2T1讀“臟”數據15
XlockB獲得讀B=100B←B*2寫回B=200CommitUnlockB①讀A=50讀B=100求和=150②③讀A=50讀B=200求和=250(驗算不對)T2T1不可重復讀162級封鎖協議1級封鎖協議+事務T在讀取數據R前必須先加S鎖,讀完后即可釋放S鎖2級封鎖協議可以防止丟失修改和讀“臟”數據。在2級封鎖協議中,由于讀完數據后即可釋放S鎖,所以它不能保證可重復讀。17不可重復讀①
SclockA獲得讀A=50UnlockA②SclockB獲得讀B=100UnlockB③求和=150
XlockB等待等待獲得XlockB讀B=100B←B*2寫回B=200CommitUnlockBT2T1④SclockA獲得讀A=50UnlockASclockB獲得讀B=200UnlockB求和=250(驗算不對)
T2T1(續)183級封鎖協議1級封鎖協議+事務T在讀取數據R之前必須先對其加S鎖,直到事務結束才釋放3級封鎖協議可防止丟失修改、讀臟數據和不可重復讀。19T1T2①
SlockA讀A=50SlockB讀B=100求和=150②
③讀A=50讀B=100求和=150CommitUnlockAUnlockB④
⑤
XlockB等待等待等待等待等待等待等待等待獲得XlockB讀B=100B←B*2寫回B=200CommitUnlockB
可重復讀T1T2①
XlockC讀C=100C←C*2寫回C=200②
③ROLLBACK(C恢復為100)UnlockC④
⑤
SlockC等待等待等待等待獲得SlockC讀C=100CommitCUnlockC不讀“臟”數據20三級協議的主要區別什么操作需要申請封鎖何時釋放鎖(即持鎖時間)封鎖協議小結21封鎖效果演示228.4活鎖和死鎖封鎖技術可以有效地解決并行操作的一致性問題,但也帶來一些新的問題死鎖活鎖23活鎖T2有可能永遠等待,這就是活鎖的情形。24采用先來先服務的策略:當多個事務請求封鎖同一數據對象時按請求封鎖的先后次序對這些事務排隊該數據對象上的鎖一旦釋放,首先批準申請隊列中第一個事務獲得鎖。如何避免活鎖25死鎖T1和T2兩個事務永遠不能結束,形成死鎖。26解決死鎖的方法預防死鎖
一次封鎖法
順序封鎖法死鎖的診斷與解除
超時法
等待圖法結論操作系統中廣為采用的預防死鎖的策略并不很適合數據庫DBMS解決死鎖更普遍采用的是診斷并解除死鎖的方法27一次封鎖法要求每個事務必須一次將所有要使用的數據全部加鎖,否則就不能繼續執行。一次封鎖法存在的問題:降低并發度將以后要用到的全部數據加鎖,勢必擴大了封鎖的范圍,從而降低了系統的并發度。執行過程時很難事先精確地確定每個事務所要封鎖地數據對象,須將執行過程中可能要封鎖的對象全部加鎖,從而進一步降低了并發度。28順序封鎖法順序封鎖法是預先對數據對象規定一個封鎖順序,所有事務都按這個順序實行封鎖。例:規定數據對象的封鎖順序為A,B,C,D,E。事務T3起初要求封鎖數據對象B,C,E,但當它封鎖了B,C后,才發現還需要封鎖A,這樣就破壞了封鎖順序.順序封鎖法存在的問題數據庫系統中可封鎖的數據對象極其眾多,并且不斷地變化,要維護這樣的資源的封鎖順序非常困難,成本很高。很難事先確定每個事務要封鎖的對象,因此很難按規定的順序去施加封鎖。29超時法如果一個事務的等待時間超過了規定的時限,就認為發生了死鎖。優點:實現簡單缺點有可能誤判死鎖時限若設置得太長,死鎖發生后不能及時發現30等待圖法用事務等待圖動態反映所有事務的等待情況事務等待圖是一個有向圖G=(T,U)T為結點的集合,每個結點表示正運行的事務U為邊的集合,每條邊表示事務等待的情況若T1等待T2,則T1,T2之間劃一條有向邊,從T1指向T2并發控制子系統周期性地(比如每隔1min)檢測事務等待圖,如果發現圖中存在回路,則表示系統中出現了死鎖。解除死鎖選擇一個處理死鎖代價最小的事務,將其撤消,釋放此事務持有的所有的鎖,使其它事務能繼續運行下去。318.5并發調度的可串行性
什么樣的并發操作調度是正確的
如何保證并發操作的調度是正確的32并發調度正確的判斷計算機系統對并行事務中并行操作的調度是的隨機的,而不同的調度可能會產生不同的結果。如果一個事務運行過程中沒有其他事務在同時運行,也就是說它沒有受到其他事務的干擾,那么就可以認為該事務的運行結果是正常的。以不同的順序串行執行事務有可能會產生不同的結果,但由于不會將數據庫置于不一致狀態,所以都認為是正確的。
幾個事務的并行執行是正確的,當且僅當其結果與按某一次序串行地執行它們時的結果相同。這種并行調度策略稱為可串行化(Serializable)的調度。33可串行性是并行事務正確性的唯一準則例:現在有兩個事務,分別包含下列操作:事務1:讀B;A=B+1;寫回A;事務2:讀A;B=A+1;寫回B;假設A的初值為2,B的初值為2。對這兩個事務的不同調度策略串行執行串行調度策略1串行調度策略2交錯執行不可串行化的調度可串行化的調度34SlockBY=B=2UnlockBXlockAA=Y+1寫回A(=3)UnlockA
SlockAX=A=3UnlockAXlockBB=X+1寫回B(=4)UnlockB
T1T2
SlockBY=B=3UnlockBXlockAA=Y+1寫回A(=4)UnlockA
SlockAX=A=2UnlockAXlockBB=X+1寫回B(=3)UnlockB
T1T2串行調度策略,正確的調度35SlockBY=B=2UnlockBXlockA
A=Y+1寫回A(=3)UnlockA
SlockA等待等待等待X=A=3UnlockAXlockBB=X+1寫回B(=4)UnlockBT1T2SlockBY=B=2
UnlockB
XlockAA=Y+1寫回A(=3)
UnlockA
SlockAX=A=2
UnlockA
XlockBB=X+1寫回B(=3)
UnlockBT1T2不可串行化的調度可串行化的調度36并發調度正確的保證從理論上講,在某一事務執行時禁止其他事務執行的調度策略一定是可串行化的調度,這也是最簡單的調度策略,但這種方法實際上是不可行的,因為它使用戶不能充分共享數據庫資源。保證并發操作調度正確性的方法封鎖方法:兩段鎖(Two-PhaseLocking,簡稱2PL)協議時標方法樂觀方法378.6兩段鎖協議兩段鎖協議(加鎖和解鎖)的內容在對任何數據進行讀、寫操作之前,事務首先要獲得對該數據的封鎖。在釋放一個封鎖之后,事務不再獲得任何其他封鎖。“兩段”鎖的含義事務分為兩個階段第一階段是獲得封鎖,也稱為擴展階段;第二階段是釋放封鎖,也稱為收縮階段。38例:事務1的封鎖序列:SlockA...SlockB...XlockC...UnlockB...UnlockA...UnlockC;事務2的封鎖序列:SlockA...UnlockA...SlockB...XlockC...UnlockC...UnlockB;事務1遵守兩段鎖協議,而事務2不遵守兩段協議。39并行執行的所有事務均遵守兩段鎖協議,則對這些事務的所有并行調度策略都是可串行化的。
所有遵守兩段鎖協議的事務,其并行執行的結果一定是正確的。事務遵守兩段鎖協議是可串行化調度的充分條件,而不是必要條件。可串行化的調度中,不一定所有事務都必須符合兩段鎖協議。40T1SlockB讀B=2Y=BXlockA
A=Y+1寫回A=3UnlockBUnlockA
T2
SlockA等待等待等待等待等待SlockA讀A=3Y=AXlockBB=Y+1寫回B=4UnlockBUnlockA
T1SlockB讀B=2Y=BUnlockBXlockA
A=Y+1寫回A=3UnlockA
T2
SlockA等待等待等待等待SlockA讀A=3X=AUnlockAXlockBB=X+1寫回B=4UnlockB
(a)遵守兩段鎖協議
(b)不遵守兩段鎖協議T1SlockB讀B=2Y=BUnlockBXlockAA=Y+1寫回A=3UnlockAT2
SlockA讀A=2X=AUnlockAXlockB等待XlockBB=X+1寫回B=3UnlockB
(c)不遵守兩段鎖協議41一次封鎖法要求每個事務必須一次將所有要使用的數據全部加鎖,否則就不能繼續執行,因此一次封鎖法遵守兩段鎖協議。但是兩段鎖協議并不要求事務必須一次將所有要使用的數據全部加鎖,因此遵守兩段鎖協議的事務可能發生死鎖。兩段鎖協議與防止死鎖的一次封鎖法42T1SlockB讀B=2
XlockA等待等待T2
SlockA讀A=2
XlockB等待圖遵守兩段鎖協議的事務發生死鎖438.7封鎖的粒度X鎖和S鎖都是加在某一個數據對象上的封鎖的對象:邏輯單元,物理單元例:在關系數據庫中,封鎖對象:邏輯單元:屬性值、屬性值集合、元組、關系、索引項、整個索引、整個數據庫等。物理單元:頁(數據頁或索引頁)、塊等。封鎖對象可以很大也可以很小例:對整個數據庫加鎖或對某個屬性值加鎖44封鎖對象的大小稱為封鎖的粒度(Granularity)多粒度封鎖(multiplegranularitylocking)在一個系統中同時支持多種封鎖粒度供不同的事務選擇封鎖的粒度越大小系統被封鎖的對象少多并發度小高系統開銷小大選擇封鎖粒度:考慮封鎖機構和并發度兩個因素對系統開銷與并發度進行權衡45需要處理多個關系的大量元組的用戶事務:以數據庫為封鎖單位;需要處理大量元組的用戶事務:以關系為封鎖單元;只處理少量元組的用戶事務:以元組為封鎖單位。選擇封鎖粒度的原則468.7.1多粒度封鎖多粒度樹以樹形結構來表示多級封鎖粒度根結點是整個數據庫,表示最大的數據粒度葉結點表示最小的數據粒度
例:三級粒度樹。根結點為數據庫,數據庫的子結點為關系,關系的子結點為元組。47允許多粒度樹中的每個結點被獨立地加鎖對一個結點加鎖意味著這個結點的所有后裔結點也被加以同樣類型的鎖在多粒度封鎖中一個數據對象可能以兩種方式封鎖:顯式封鎖和隱式封鎖顯式封鎖:直接加到數據對象上的封鎖隱式封鎖:由于其上級結點加鎖而使該數據對象加上了鎖顯式封鎖和隱式封鎖的效果是一樣的48該數據對象有無顯式封鎖與之沖突所有上級結點檢查本事務的顯式封鎖是否與該數據對象上的隱式封鎖沖突:(由上級結點封鎖造成的)所有下級結點看上面的顯式封鎖是否與本事務的隱式封鎖(將加到下級結點的封鎖)沖突。對某個數據對象加鎖時系統檢查的內容498.7.2意向鎖引進意向鎖(intentionlock)目的提高對某個數據對象加鎖時系統的檢查效率對任一結點加基本鎖,必須先對它的上層結點加意向鎖;如果對一個結點加意向鎖,則說明該結點的下層結點正在被加鎖。例:對任一元組r加鎖,先關系R加意向鎖事務T要對關系R加X鎖,系統只要檢查根結點數據庫和關系R是否已加了不相容的鎖,不需要搜索和檢查R中的每一個元組是否加了X鎖50常用的意向鎖意向共享鎖(IntentShareLock,簡稱IS鎖)意向排它鎖(IntentExclusiveLock,簡稱IX鎖)共享意向排它鎖(ShareIntentExclusiveLock,簡稱SIX鎖)51IS鎖如果對一個數據對象加IS鎖,表示它的后裔結點
擬(意向)加S鎖。
例:要對某個元組加S鎖,則要首先對關系和數據庫加IS鎖。52IX鎖如果對一個數據對象加IX鎖,表示它的后裔結點擬(意向)加X鎖。例:要對某個元組加X鎖,則要首先對關系和數據庫加IX鎖。53SIX鎖如果對一個數據對象加SIX鎖,表示對它加S鎖,再加IX鎖,即SIX=S+IX。例:對某個表加SIX鎖,則表示該事務要讀整個表(所以要對該表加S鎖),同時會更新個別元組(所以要對該表加IX鎖)。54意向鎖的相容矩陣
T1T2SXISIXSIX-SYNYNNY
XNNNNNY
ISYNY
Y
Y
Y
IXNNY
YNY
SIXNNYNNY
-Y
Y
Y
Y
Y
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
評論
0/150
提交評論