AnIntroductiontoDatabaseSystem中国人民大学信息学院数据库系统概论AnIntroductiontoDatabaseSystem第十一章并发控制AnIntroductiontoDatabaseSystem并发控制*多用户数据库系统允许多个用户同时使用的数据库系统飞机定票数据库系统银行数据库系统特点:在同一时刻并发运行的事务数可达数百上千个AnIntroductiontoDatabaseSystem并发控制(续)多事务执行方式(1)事务串行执行每个时刻只有一个事务运行,其他事务必须等到这个事务结束以后方能运行不能充分利用系统资源,发挥数据库共享资源的特点T1T2T3事务的串行执行方式AnIntroductiontoDatabaseSystem并发控制(续)在单处理机系统中,事务的并行执行是这些并行事务的并行操作轮流交叉运行单处理机系统中的并行事务并没有真正地并行运行,但能够减少处理机的空闲时间,提高系统的效率(2)交叉并发方式(InterleavedConcurrency)AnIntroductiontoDatabaseSystem并发控制(续)(3)同时并发方式(simultaneousconcurrency)多处理机系统中,每个处理机可以运行一个事务,多个处理机可以同时运行多个事务,实现多个事务真正的并行运行最理想的并发方式,但受制于硬件环境更复杂的并发方式机制本章讨论的数据库系统并发控制技术是以单处理机系统为基础的AnIntroductiontoDatabaseSystem并发控制(续)事务并发执行带来的问题会产生多个事务同时存取同一数据的情况可能会存取和存储不正确的数据,破坏事务隔离性和数据库的一致性数据库管理系统必须提供并发控制机制并发控制机制是衡量一个数据库管理系统性能的重要标志之一AnIntroductiontoDatabaseSystem第十一章并发控制11.1并发控制概述11.2封锁11.3封锁协议11.4活锁和死锁11.5并发调度的可串行性11.6两段锁协议11.7封锁的粒度*11.8其他并发控制机制11.9小结AnIntroductiontoDatabaseSystem11.1并发控制概述事务是并发控制的基本单位并发控制机制的任务对并发操作进行正确调度保证事务的隔离性保证数据库的一致性AnIntroductiontoDatabaseSystemT1的修改被T2覆盖了!并发控制概述(续)并发操作带来数据的不一致性实例[例11.1]飞机订票系统中的一个活动序列①甲售票点(事务T1)读出某航班的机票余额A,设A=16;②乙售票点(事务T2)读出同一航班的机票余额A,也为16;③甲售票点卖出一张机票,修改余额A←A-1,所以A为15,把A写回数据库;④乙售票点也卖出一张机票,修改余额A←A-1,所以A为15,把A写回数据库结果明明卖出两张机票,数据库中机票余额只减少1AnIntroductiontoDatabaseSystem并发控制概述(续)这种情况称为数据库的不一致性,是由并发操作引起的。在并发操作情况下,对T1、T2两个事务的操作序列的调度是随机的。若按上面的调度序列执行,T1事务的修改就被丢失。原因:第4步中T2事务修改A并写回后覆盖了T1事务的修改AnIntroductiontoDatabaseSystem并发控制概述(续)并发操作带来的数据不一致性1.丢失修改(LostUpdate)2.不可重复读(Non-repeatableRead)3.读“脏”数据(DirtyRead)记号R(x):读数据xW(x):写数据xAnIntroductiontoDatabaseSystem1.丢失修改两个事务T1和T2读入同一数据并修改,T2的提交结果破坏了T1提交的结果,导致T1的修改被丢失。上面飞机订票例子就属此类AnIntroductiontoDatabaseSystem丢失修改(续)T1T2①R(A)=16②R(A)=16③A←A-1W(A)=15④A←A-1W(A)=15丢失修改AnIntroductiontoDatabaseSystem2.不可重复读不可重复读是指事务T1读取数据后,事务T2执行更新操作,使T1无法再现前一次读取结果。AnIntroductiontoDatabaseSystem不可重复读(续)不可重复读包括三种情况:(1)事务T1读取某一数据后,事务T2对其做了修改,当事务T1再次读该数据时,得到与前一次不同的值AnIntroductiontoDatabaseSystem不可重复读(续)T1读取B=100进行运算T2读取同一数据B,对其进行修改后将B=200写回数据库。T1为了对读取值校对重读B,B已为200,与第一次读取值不一致T1T2①R(A)=50R(B)=100求和=150②R(B)=100B←B*2W(B)=200③R(A)=50R(B)=200求和=250(验算不对)不可重复读例如:AnIntroductiontoDatabaseSystem不可重复读(续)(2)事务T1按一定条件从数据库中读取了某些数据记录后,事务T2删除了其中部分记录,当T1再次按相同条件读取数据时,发现某些记录神秘地消失了。(3)事务T1按一定条件从数据库中读取某些数据记录后,事务T2插入了一些记录,当T1再次按相同条件读取数据时,发现多了一些记录。后两种不可重复读有时也称为幻影现象(PhantomRow)AnIntroductiontoDatabaseSystem3.读“脏”数据读“脏”数据是指:事务T1修改某一数据,并将其写回磁盘事务T2读取同一数据后,T1由于某种原因被撤销这时T1已修改过的数据恢复原值,T2读到的数据就与数据库中的数据不一致T2读到的数据就为“脏”数据,即不正确的数据AnIntroductiontoDatabaseSystem读“脏”数据(续)T1T2①R(C)=100C←C*2W(C)=200②R(C)=200③ROLLBACKC恢复为100例如读“脏”数据T1将C值修改为200,T2读到C为200T1由于某种原因撤销,其修改作废,C恢复原值100这时T2读到的C为200,与数据库内容不一致,就是“脏”数据AnIntroductiontoDatabaseSystem并发控制概述(续)数据不一致性:由于并发操作破坏了事务的隔离性并发控制就是要用正确的方式调度并发操作,使一个用户事务的执行不受其他事务的干扰,从而避免造成数据的不一致性对数据库的应用有时允许某些不一致性,例如有些统计工作涉及数据量很大,读到一些“脏”数据对统计精度没什么影响,可以降低对一致性的要求以减少系统开销参见爱课程网11.1节动画《并发操作带来的数据不一致性》AnIntroductiontoDatabaseSystem并发控制概述(续)并发控制的主要技术封锁(Locking)时间戳(Timestamp)乐观控制法多版本并发控制(MVCC)AnIntroductiontoDatabaseSystem第十一章并发控制11.1并发控制概述11.2封锁11.3封锁协议11.4活锁和死锁11.5并发调度的可串行性11.6两段锁协议11.7封锁的粒度*11.8其他并发控制机制11.9小结AnIntroductiontoDatabaseSystem11.2封锁什么是封锁基本封锁类型锁的相容矩阵AnIntroductiontoDatabaseSystem什么是封锁封锁就是事务T在对某个数据对象(例如表、记录等)操作之前,先向系统发出请求,对其加锁加锁后事务T就对该数据对象有了一定的控制,在事务T释放它的锁之前,其它的事务不能更新此数据对象。封锁是实现并发控制的一个非常重要的技术AnIntroductiontoDatabaseSystem基本封锁类型一个事务对某个数据对象加锁后究竟拥有什么样的控制由封锁的类型决定。基本封锁类型排它锁(ExclusiveLocks,简记为X锁)共享锁(ShareLocks,简记为S锁)AnIntroductiontoDatabaseSystem排它锁排它锁又称为写锁若事务T对数据对象A加上X锁,则只允许T读取和修改A,其它任何事务都不能再对A加任何类型的锁,直到T释放A上的锁保证其他事务在T释放A上的锁之前不能再读取和修改AAnIntroductiontoDatabaseSystem共享锁共享锁又称为读锁若事务T对数据对象A加上S锁,则事务T可以读A但不能修改A,其它事务只能再对A加S锁,而不能加X锁,直到T释放A上的S锁保证其他事务可以读A,但在T释放A上的S锁之前不能对A做任何修改AnIntroductiontoDatabaseSystem锁的相容矩阵Y=Yes,相容的请求N=No,不相容的请求T1XS_XNNYSNYY_YYYT2AnIntroductiontoDatabaseSystem第十一章并发控制11.1并发控制概述11.2封锁11.3封锁协议11.4活锁和死锁11.5并发调度的可串行性11.6两段锁协议11.7封锁的粒度*11.8其他并发控制机制11.9小结AnIntroductiontoDatabaseSystem11.3封锁协议什么是封锁协议在运用X锁和S锁对数据对象加锁时,需要约定一些规则,这些规则为封锁协议(LockingProtocol)。何时申请X锁或S锁持锁时间何时释放对封锁方式规定不同的规则,就形成了各种不同的封锁协议,它们分别在不同的程度上为并发操作的正确调度提供一定的保证。AnIntroductiontoDatabaseSystem保持数据一致性的常用封锁协议三级封锁协议1.一级封锁协议2.二级封锁协议3.三级封锁协议AnIntroductiontoDatabaseSystem1.一级封锁协议一级封锁协议事务T在修改数据R之前必须先对其加X锁,直到事务结束才释放。正常结束(COMMIT)非正常结束(ROLLBACK)一级封锁协议可防止丢失修改,并保证事务T是可恢复的。在一级封锁协议中,如果仅仅是读数据不对其进行修改,是不需要加锁的,所以它不能保证可重复读和不读“脏”数据。AnIntroductiontoDatabaseSystem使用封锁机制解决丢失修改问题T1T2①XlockA②R(A)=16XlockA③A←A-1等待W(A)=15等待Commit等待UnlockA等待④获得XlockAR(A)=15A←A-1⑤W(A)=14CommitUnlockA例:事务T1在读A进行修改之前先对A加X锁当T2再请求对A加X锁时被拒绝T2只能等待T1释放A上的锁后获得对A的X锁这时T2读到的A已经是T1更新过的值15T2按此新的A值进行运算,并将结果值A=14写回到磁盘。避免了丢失T1的更新。没有丢失修改AnIntroductiontoDatabaseSystem2.二级封锁协议二级封锁协议一级封锁协议加上事务T在读取数据R之前必须先对其加S锁,读完后即可释放S锁。二级封锁协议可以防止丢失修改和读“脏”数据。在二级封锁协议中,由于读完数据后即可释放S锁,所以它不能保证可重复读。AnIntroductiontoDatabaseSystem使用封锁机制解决读“脏”数据问题T1T2①XlockCR(C)=100C←C*2W(C)=200②SlockC等待③ROLLBACK等待(C恢复为100)等待UnlockC等待④获得SlockCR(C)=100⑤CommitCUnlockC例事务T1在对C进行修改之前,先对C加X锁,修改其值后写回磁盘T2请求在C上加S锁,因T1已在C上加了X锁,T2只能等待T1因某种原因被撤销,C恢复为原值100T1释放C上的X锁后T2获得C上的S锁,读C=100。避免了T2读“脏”数据不读“脏”数据AnIntroductio