Oracle中的死锁怎么理解
死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去。死锁是比较普遍存在的现象,出现死锁的原因有很多,但是都可以归结为两个:一是进程的推进顺序不当,二是资源分配不当。
死锁的产生需要以下四个条件:
互斥条件:一个资源每次只能被一个进程使用,即在一段时间内某资源只能为某进程所占有。
请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
不剥夺条件:进程已获得的资源,在未使用完之前,不能被剥夺。
循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。
死锁的处理方法有两种:一种是系统自动检测死锁并解除死锁,另一种是程序设计者自己在程序中设计处理死锁的机制。
死锁的解除方法有两种:一种是终止其中一个或者几个发生死锁的进程,释放这些进程占有的资源,使得其他进程得以运行;另一种是终止所有进程,重新启动系统。
相关文章