热门关键字:  项目经理  分析师  中间件  CEO  报名费





死锁

来源: 作者: 时间:2008-04-02 点击:

(1)产生死锁的原因


如果事务T1封锁了数据R1,T2封锁了数据R2,然后T1又请求封锁R2,因T2已封锁了R2,于是T1等待T2释放R2上的锁.接着T2又申请封锁R1,因T1已封锁了R1,T2也只能等待T1释放R1上的锁.这样就出现了T1在等待T2,而T2又在等待T1的局面,T1和T2两个事务永远不能结束,形成死锁.


顺序
事务T1
事务T2

Lock R1

Lock R2

请求Lock R2

等待
请求Lock R1

等待
等待

永远等待
永远等待


(2) 死锁的预防


在数据库中,产生死锁的原因是两个或多个事务都已封锁了一些数据对象,然后又都请求对已被其他事务封锁的数据对象加锁,从而出现死等待.防止死锁的发生其实就是要破坏产生死锁的条件.预防死锁通常有两种方法:


①一次封锁法


一次封锁法要求每个事务必须一次将所有要使用的数据全部加锁,否则就不能继续执行.一次封锁法虽然可以有效地防止死锁的发生,但也存在问题,一次就将以后要用到的全部数据加锁,势必扩大了封锁的范围,从而降低了系统的并发度.


②顺序封锁法


顺序封锁法是预先对数据对象规定一个封锁顺序,所有事务都按这个顺序实行封锁.顺序封锁法可以有效地防止死锁,但也同样存在问题.事务的封锁请求可以随着事务的执行而动态地决定,很难事先确定每一个事务要封锁哪些对象,因此也就很难按规定的顺序去施加封锁.


可见,可用一次封锁法和顺序封锁法预防死锁,但是不能根本消除死锁,因此DBMS在解决死锁的问题上还要有诊断并解除死锁的方法.


(3) 死锁的诊断与解除


①超时法


如果一个事务的等待时间超过了规定的时限,就认为发生了死锁.超时法实现简单,但其不足也很明显.一是有可能误判死锁,事务因为其他原因使等待时间超过时限,系统会误认为发生了死锁.二是时限若设置得太长,死锁发生后不能及时发现.


②等待图法


事务等待图是一个有向图G=(T,U).T为结点的集合,每个结点表示正运行的事务;U为边的集合,每条边表示事务等待的情况.若T1等待T2 ,则T1,T2之间划一条有向边,从T1指向T2.事务等待图动态地反映了所有事务的等待情况.并发控制子系统周期性地(比如每隔1分钟)检测事务等待图,如果发现图中存在回路,则表示系统中出现了死锁.


DBMS的并发控制子系统一旦检测到系统中存在死锁,就要设法解除.通常采用的方法是选择一个处理死锁代价最小的事务,将其撤消,释放此事务持有的所有的锁,使其它事务得以继续运行下去.当然,对撤消的事务所执行的数据修改操作必须加以恢复.

上一篇:不加锁的并发控制
下一篇:封锁粒度




最新评论共有 0 位网友发表了评论
发表评论
评论内容:不能超过250字,需审核,请自觉遵守互联网相关政策法规。
用户名: 密码:
匿名?
注册
企业电子商务

赞助商