并发控制课件.pptVIP

并发控制课件.ppt

此“教育”领域文档为创作者个人分享资料,不作为权威性指导和指引,仅供参考
  1. 1、本文档共119页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

什麼是封鎖粒度(續)封鎖對象可以很大也可以很小例:對整個資料庫加鎖對某個屬性值加鎖封鎖對象的大小稱為封鎖的粒度(Granularity)多粒度封鎖(multiplegranularitylocking)在一個系統中同時支持多種封鎖粒度供不同的事務選擇檢測死鎖:超時法如果一個事務的等待時間超過了規定的時限,就認為發生了死鎖優點:實現簡單缺點有可能誤判死鎖時限若設置得太長,死鎖發生後不能及時發現等待圖法用事務等待圖動態反映所有事務的等待情況事務等待圖是一個有向圖G=(T,U)T為結點的集合,每個結點表示正運行的事務U為邊的集合,每條邊表示事務等待的情況若T1等待T2,則T1,T2之間劃一條有向邊,從T1指向T2併發控制子系統週期性地(比如每隔1min)檢測事務等待圖,如果發現圖中存在回路,則表示系統中出現了死鎖。死鎖的診斷與解除(續)解除死鎖選擇一個處理死鎖代價最小的事務,將其撤銷,釋放此事務持有的所有的鎖,使其他事務能繼續運行下去。第八章併發控制8.1併發控制概述8.2封鎖8.3封鎖協議8.4活鎖和死鎖8.5併發調度的可串行性8.6兩段鎖協議8.7封鎖的粒度8.8Oracle的併發控制8.9小結8.5併發調度的可串行性一、什麼樣的併發操作調度是正確的二、如何保證併發操作的調度是正確的8.5併發調度的可串行性一、什麼樣的併發操作調度是正確的二、如何保證併發操作的調度是正確的一、什麼樣的併發操作調度是正確的電腦系統對並行事務中並行操作的調度是的隨機的,而不同的調度可能會產生不同的結果。將所有事務串行起來的調度策略一定是正確的調度策略。如果一個事務運行過程中沒有其他事務在同時運行,也就是說它沒有受到其他事務的干擾,那麼就可以認為該事務的運行結果是正常的或者預想的什麼樣的併發操作調度是正確的(續)以不同的順序串行執行事務也有可能會產生不同的結果,但由於不會將資料庫置於不一致狀態,所以都可以認為是正確的。幾個事務的並行執行是正確的,當且僅當其結果與按某一次序串行地執行它們時的結果相同。這種並行調度策略稱為可串行化(Serializable)的調度。什麼樣的併發操作調度是正確的(續)可串行性是並行事務正確性的唯一準則例:現在有兩個事務,分別包含下列操作:事務1:讀B;A=B+1;寫回A;事務2:讀A;B=A+1;寫回B;假設A的初值為2,B的初值為2。什麼樣的併發操作調度是正確的(續)對這兩個事務的不同調度策略串行執行串行調度策略1串行調度策略2交錯執行不可串行化的調度可串行化的調度(a)串行調度策略,正確的調度SlockBY=B=2UnlockBXlockAA=Y+1寫回A(=3)UnlockA???????SlockAX=A=3UnlockAXlockBB=X+1寫回B(=4)UnlockBT1T2(b)串行調度策略,正確的調度???????SlockBY=B=3UnlockBXlockAA=Y+1寫回A(=4)UnlockASlockAX=A=2UnlockAXlockBB=X+1寫回B(=3)UnlockB?????T1T2(c)不可串行化的調度SlockBY=B=2??UnlockB?XlockAA=Y+1寫回A(=3)???UnlockA??SlockAX=A=2?UnlockA???XlockBB=X+1寫回B(=3)?UnlockBT1T2(c)不可串行化的調度(續)由於其執行結果與(a)、(b)的結果都不同,所以是錯誤的調度。(d)可串行化的調度SlockBY=B=2UnlockBXlockA?A=Y+1寫回A(=3)UnlockA????????SlockA等待等待等待X=A=3UnlockAXlockBB=X+1寫回B(=4)UnlockBT1T2(d)可串行化的調度(續)由於其執行結果與串行調度(a)的執行結果相同,所以是正確的調度。8.5併發調度的可串行性一、什麼樣的併發操作調度是正確的二、如何保證併發操作的調度是正確的二、如何保證併發操作的調度是正確的為了保證並行操作的正確

文档评论(0)

子不语 + 关注
官方认证
服务提供商

平安喜乐网络服务,专业制作各类课件,总结,范文等文档,在能力范围内尽量做到有求必应,感谢

认证主体菏泽喜乐网络科技有限公司
IP属地山东
统一社会信用代码/组织机构代码
91371726MA7HJ4DL48

1亿VIP精品文档

相关文档