日期:2014-05-16  浏览次数:20390 次

Oracle行级锁的本质

        ㈠ 单实例Oracle locking机制
       
           locking机制的三大组成部分:
       
           ① resource structure
           
              Oracle对于每个需要“并发访问”的资源,都在SGA中用一个数据结构来描述它
              这个结构叫resource structure
              这个数据结构有三个成员:owner、waiter和converter
              这是3个指针
              指向由lock structure组成的链表的指针
              
              其中,converter和waiter有些区别:
              如果某个操作先后需要两种不同模式的锁,比如,先S,后X,则进程会先请求S,获得后lock structure会挂在owner上,
              当需要X时,进行必须先释放S,然后再次申请X
              但是可能无法立即获得
              这时这个请求会被立即挂在converter下
              converter的优先级高于waiter
              根据v$lock的lmode和request可以判断他三:
                ● lmode > 0,request =0  → owner
                ● lmode = 0,request >0  → waiter
                ● lmode > 0,request >0  → converter
             
     
           ② lock structure
          
              每当进程要访问共享资源时,必须先锁定该资源
              锁定实际就是从SGA中申请一个lock structure
              在其中记录lmode 、PID等
              然后看能否立刻获得该资源的访问权
                ● 如果能,则把lock structure挂到resource structure的owner链表中
                ● 否则,把这个lock structure挂到resource structure的waiter链表中
          
             
           ③ enqueue算法
          
              按先入先出原则分配锁
            &n