




已阅读5页,还剩45页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
数据库原理,主讲:赵海霞,河南科技大学电信学院,第十一章 并发控制,并发控制概述 封锁 封锁协议 活锁和死锁 并发调度的可串行性 两段锁协议 封锁的粒度,问题的产生,多用户数据库系统的存在 允许多个用户同时使用的数据库系统 飞机定票数据库系统 银行数据库系统 特点:在同一时刻并发运行的事务数可达数百个,数据库系统中的并发,如果事务顺序执行,即一个事务完全结束后,另一个事务才开始,则称这种执行方式为串行访问(serial access) 如果DBMS可以同时接纳多个事务,事务可以在时间上重叠执行,则称这种执行方式为并发访问(concurrent access),交叉并发和同时并发,在单CPU系统中,同一时间只能有一个事务占用CPU,各个事务交叉地使用CPU,这种并发方式称为交叉并发(interleaved concurrency) 在多CPU系统中,可以允许多个事务同时占有CPU,这种并发方式称为同时并发(simultaneous concurrency),并发的目的,改善系统的资源利用率 对一个事务来讲,在不同的执行阶段需要不同的资源,有时需要CPU,有时需要访问磁盘,有时需要通信。如果事务并发执行,可以交叉地利用这些资源,有利于提高系统的资源利用率 改善短事务的响应时间,T1,T2,11.1 并发控制概述,事务ACID特性可能遭到破坏的原因之一是多个事务对数据库的并发操作 DBMS的并发控制子系统负责协调并发事务的执行,保证数据库的一致性不受破坏。同时避免用户得到不正确的数据。,T1 T2 Tn,DB (consistency constraints),示例,结果明明卖出两张机票,数据库中机票余额只减少1,机票数量A,A=16,A=15,A=15,售票点,售票点,A=16,A=16,出售1,出售1,事务甲,事务乙,示例(续),这种情况称为数据库的不一致性,是由并发操作引起的。 在并发操作情况下,对甲、乙两个事务的操作序列的调度是随机的。 若按上面的调度序列执行,甲事务的修改就被丢失。 原因:第4步中乙事务修改A并写回后覆盖了甲事务的修改,事务并发操作带来的问题,并发操作引起的数据不一致性包括三类 丢失修改 不可重复读 读脏数据,事务并发带来的丢失修改,A、丢失修改问题 两个事务T1和T2读入同一数据并修改,T2的提交结果破坏了T1提交的结果,导致T1的修改被丢失。 上面飞机订票例子就属此类,A、丢失修改问题,A的初值为16,事务T1对A减1,事务T2对A减1 。,在时间t7丢失了事务T1的更新。,事务并发带来的丢失修改,并发操作引起的不可重复读,B、不可重复读 不可重复读是指事务T1读取数据后,事务T2执行更新操作,使T1无法再现前一次读取结果。,并发操作引起的不可重复读,B、不可重复读 不可重复读包括三种情况: (1)事务T1读取某一数据后,事务T2对其做了修改,当事务T1再次读该数据时,得到与前一次不同的值,T1 读A=1,B=2 求A+B=3 读A=1,B=4 求A+B=5,T2 读B=2 B=B*2 写回B=4,并发操作引起的不可重复读,(2)事务T1按一定条件从数据库中读取了某些数据记录后,事务T2删除了其中部分记录,当T1再次按相同条件读取数据时,发现某些记录消失了 (3)事务T1按一定条件从数据库中读取某些数据记录后,事务T2插入了一些记录,当T1再次按相同条件读取数据时,发现多了一些记录。 后两种不可重复读有时也称为幻影现象(Phantom Row),事务并发带来的读脏数据,C、读“脏”数据 读“脏”数据是指: 事务T1修改某一数据,并将其写回磁盘 事务T2读取同一数据后,T1由于某种原因被撤销 这时T1已修改过的数据恢复原值,T2读到的数据就与数据库中的数据不一致 T2读到的数据就为“脏”数据,即不正确的数据,C、读“脏”数据,事务T1对C乘2,但未提交,事务T4读未提交的A值,而T1做ROLLBACK操作。,在时间t4,事务T4读了未提交的值。,事务并发带来的读脏数据,小结,产生上述三类不一致性的主要原因 并发操作破坏了事务的隔离性,事务间相互干扰 三种主要解决技术 封锁技术 (Locking) 时间戳技术(Timestamp) 乐观控制法 商用的DBMS一般都采用封锁方法,11.2 封锁,概念 事务T在对某个数据对象(如数据库、表、记录等)操作之前,首先向系统发出加锁请求以便获得对数据对象相应的控制 在事务T释放它所获得的锁之前,其他事务不能更新此数据对象,锁的类型,一个事务对某个数据对象加锁后究竟拥有什么样的控制由封锁的类型决定。 排它锁(eXclusive lock):写锁 若事务T对数据对象A加上X锁,则只允许T读取和修改A,其它任何事务都不能再对A加任何类型的锁,直到T释放A上的锁 保证其他事务在T释放A上的锁之前不能再读取和修改A 共享锁(Share lock):读锁 若事务T对数据对象A加上S锁,则事务T可以读A但不能修改A,其它事务只能再对A加S锁,而不能加X锁,直到T释放A上的S锁 保证其他事务可以读A,但在T释放A上的S锁之前不能对A做任何修改,锁的相容矩阵,Y:相容的请求 N:不相容的请求,T1,T2,T1,T2,T1,T2,Xlock A,获得Xlock A,读A = 16,A = A -1,写回A = 15,Commit,Unlock A,Xlock A,等待,等待,获得Xlock A,读A = 15,Commit,Unlock A,等待,等待,A = A -1,写回A = 14,Slock A,Slock B,读A = 50,求和 = 150,读A = 50,Commit,Unlock A,Xlock B,等待,等待,获得Xlock B,读B = 100,Commit,Unlock B,等待,等待,B = B * 2,写回B = 200,读B = 100,读B = 100,求和 = 150,Unlock B,等待,等待,等待,等待,Xlock C,读C = 100,C= C * 2,写回C = 200,Rollback (C恢复为100),Unlock C,Slock C,等待,等待,获得Slock C,读C = 100,Commit,Unlock C,等待,没有丢失修改,可重复读,不读脏数据,用封锁机制解决三种数据不一致性的示例,11.3 活锁和死锁问题,封锁技术可以有效地解决并行操作的一致性问题,但也带来一些新的问题 死锁 活锁,活锁问题,活锁 举例说明: 事务T1封锁某数据后,事务T2请求封锁未获得并等待,而T1释放锁后,事务T3请求封锁并获得,T3释放锁后,事务T4请求封锁并获得T2可能永远等待 解决办法:采用先来先服务的策略,死锁问题,死锁 举例说明: 事务T1和T2各自封锁了数据R1和R2后,又各自请求封锁R2和R1,因都无法获得而等待对方释放的现象 解决的两类方法 预防死锁 允许发生死锁,采用一定手段定期诊断并解除死锁,死锁的预防,一次封锁法 办法:每个事务一次将所有要使用的数据全部加锁 存在问题?降低系统并发度;难于事先精确确定封锁对象 顺序封锁法 办法:预先规定数据对象的封锁顺序,所有事务均按此顺序 存在问题?维护成本:数据库系统中封锁的数据对象极多,并且在不断地变化;难以实现:很难事先确定每一个事务要封锁哪些对象,在操作系统上广为采用的预防死锁的策略并不很适合数据库的特点 因此DBMS普遍采用诊断并解除死锁的办法,死锁的诊断与解决,死锁的诊断 超时法 办法:等待时间超过规定的时限 问题? 等待图法 办法:画等待图,发现回路 死锁的解决 检测到死锁,选择一个处理死锁代价最小的事务,强行撤销,使其它事务可以继续下去 恢复撤销事务所执行的数据修改操作,11.4 事务调度的可串行性,引言 DBMS对并发事务不同的调度可能会产生不同的结果 什么样的调度是正确的? 概念 可串行化的调度:多个事务的并发执行是正确的,当且仅当其结果与按某一次序串行地执行它们时的结果相同 可串行性是并发事务操作是否正确的判别准则,事务调度的可串行性,为了保证并发操作的正确性,DBMS的并发控制机制必须提供一定的手段来保证调度是可串行化的 保证事务调度可串行性的策略 事务排它式执行(资源无法充分共享) 两段锁(Two-Phase Locking, 2PL)协议 其它,如时间戳(TimeStamp)方法等 DBMS普通采用封锁方法实现并发操作调度的可串行性,并发事务的不同调度策略,T1,T2,T1,T2,T1,T2,Slock B,Y = B = 2,Unlock B,Xlock A,A = Y + 1,写回A(=3),Unlock A,X = A = 3,Unlock A,写回B(=4),Unlock B,Slock A,Xlock B,B = X + 1,a 串行调度,c 不可串行化的调度 (结果与a,b不同,错误调度),Slock B,Y = B = 2,Unlock B,Xlock A,A = Y + 1,写回A(=3),Unlock A,X = A = 2,Unlock A,写回B(=3),Unlock B,Slock A,Xlock B,B = X + 1,Slock B,Y = B = 2,Unlock B,Xlock A,A = Y + 1,写回A(=3),Unlock A,Slock A,X = A = 3,Unlock A,写回B(=4),Unlock B,Xlock B,B = X + 1,等待,等待,等待,T1,T2,Slock B,Y = B = 3,Unlock B,Xlock A,A = Y + 1,写回A(=4),Unlock A,X = A = 2,Unlock A,写回B(=3),Unlock B,Slock A,Xlock B,B = X + 1,d 可串行化的调度 (结果与a相同,正确调度),T1: 读B; A=B+1; 写回A; T2: 读A; B=A+1; 写回B; A,B初值均为2,b 串行调度,冲突可串行化调度,可串行化调度的充分条件 一个调度Sc在保证冲突操作的次序不变的情况下,通过交换两个事务不冲突操作的次序得到另一个调度Sc,如果Sc是串行的,称调度Sc为冲突可串行化的调度 一个调度是冲突可串行化,一定是可串行化的调度,冲突可串行化调度(续),冲突操作 冲突操作是指不同的事务对同一个数据的读写操作和写写操作 Ri (x)与Wj(x) /* 事务Ti读x,Tj写x*/ Wi(x)与Wj(x) /* 事务Ti写x,Tj写x*/ 其他操作是不冲突操作 不同事务的冲突操作和同一事务的两个操作不能交换(Swap),冲突可串行化调度(续),例今有调度Sc1=r1(A)w1(A)r2(A)w2(A)r1(B)w1(B)r2(B)w2(B) 把w2(A)与r1(B)w1(B)交换,得到: r1(A)w1(A)r2(A)r1(B)w1(B)w2(A)r2(B)w2(B) 再把r2(A)与r1(B)w1(B)交换: Sc2r1(A)w1(A)r1(B)w1(B)r2(A)w2(A)r2(B)w2(B) Sc2等价于一个串行调度T1,T2,Sc1冲突可串行化的调度,冲突可串行化调度(续),冲突可串行化调度是可串行化调度的充分条件,不是必要条件。还有不满足冲突可串行化条件的可串行化调度。 例有3个事务 T1=W1(Y)W1(X),T2=W2(Y)W2(X),T3=W3(X) 调度L1=W1(Y)W1(X)W2(Y)W2(X) W3(X)是一个串行调度。 调度L2=W1(Y)W2(Y)W2(X)W1(X)W3(X)不满足冲突可串行化。但是调度L2是可串行化的,因为L2执行的结果与调度L1相同,Y的值都等于T2的值,X的值都等于T3的值,11.5 两段锁协议,封锁协议 运用封锁方法时,对数据对象加锁时需要约定一些规则 何时申请封锁 持锁时间 何时释放封锁等 两段封锁协议(Two-Phase Locking,简称2PL)是最常用的一种封锁协议,理论上证明使用两段封锁协议产生的是可串行化调度,两段锁协议(续),概念:事务对数据项的加锁和解锁分为两个阶段完成 获得封锁:在对数据读写之前首先申请并获得封锁; 释放封锁:在释放一个封锁后不再申请和获得任何其他封锁,两段锁协议(续),两段”锁的含义 事务分为两个阶段 第一阶段是获得封锁,也称为扩展阶段 事务可以申请获得任何数据项上的任何类型的锁,但是不能释放任何锁 第二阶段是释放封锁,也称为收缩阶段 事务可以释放任何数据项上的任何类型的锁,但是不能再申请任何锁,两段锁协议(续),如遵守两段锁协议的事务 Slock A Slock B Xlock C . Unlock B Unlock A Unlock C 如不遵守两段锁协议的事务 Slock A Unlock A Slock B . Xlock C Unlock C Unlock B,两段锁协议的性质,两段锁协议是可串行化调度的充分条件,但不是必要条件 若并发事务都遵守两段锁协议,则对这些事务的任何并发调度策略都是可串行化的; 若对并发事务的一个调度是可串行化的,不一定所有事务都符合两段锁协议 两段锁协议可以保证并发事务的正确性,但可能发生死锁,T1,T2,T1,T2,T1,T2,Slock B,读B=2,Y=B,A = Y+1,写回A = 3,Unlock B,Unlock A,Slock A,等待,等待,读A = 3,Unlock B,Unlock A,等待,等待,Y = A,写回B(=4),Slock B,读B=2,Y=B,Xlock A,A=Y+1,Slock A,等待,等待,读A = 3,Xlock B,B=X+1,等待,等待,X = A,Unlock A,Unlock B,写回A(=3),Unlock A,Slock B,读B = 2,Xlock A,Slock A,等待,Xlock B,等待,可串行调度 遵守两段锁协议,可串行调度 不遵守两段锁协议,遵守两段锁协议的事务发生死锁,关于两段锁协议,Xlock A,等待,Xlock B,B=Y+1,写回B(=4),Unlock B,读A = 2,等待,11.6 封锁的粒度,封锁的粒度即封锁对象的大小,如 逻辑单元:属性、元组、关系、索引、数据库等 物理单元:页(数据页或索引页)、 块等,封锁粒度与系统并发的关系,封锁的数据单元就越,封锁的粒度越,少,并发度就越,系统的开销也越,大,低,小,封锁的数据单元就越,封锁的粒度越
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 杭州公寓退房协议书
- 教师帮扶学生协议书
- 毁坏他人作物协议书
- 村民砍树赔偿协议书
- 朋友之间回迁协议书
- 打架治安调解协议书
- 服装委托代销协议书
- 朋友借车赔偿协议书
- 撞死宠物赔偿协议书
- 树木砍伐承担协议书
- 采矿管理协议书范本
- 话剧导演合同协议
- 客服代理合同协议
- 广西壮族自治区2025年4月高三毕业班诊断学考试数学试卷及答案(广西三模)
- 安徽中医药大学专职辅导员招聘笔试真题2024
- 躁狂症病人的护理
- 高中女生预防性侵教育
- 医院建设项目医疗专项工程医用气体工程技术参数及要求
- 2025年西城二模化学试题及答案
- 2025年1月浙江省普通高校招生选考化学化学试题(解析版)
- 主播语音与发声知到课后答案智慧树章节测试答案2025年春上海电影艺术职业学院
评论
0/150
提交评论