`

oracle 死锁和锁等待的区别(转载)

 
阅读更多
oracle 死锁和锁等待的区别(转载)

所谓的锁等待:就是一个事务a对一个数据表进行ddl或是dml操作时,系统就会对该表加上表级的排它锁,此时其他的事务对该表进行操作的时候会等待a提交或是回滚后,才可以继续b的操作

所谓的死锁:当两个或多个用户相互等待锁定的数据时就会发生死锁,这时这些用户被卡在不能继续处理业务,oracle可以自动检测死锁并解决他们,通过回滚一个死锁中的语句,释放锁定的数据,回滚的话会遇到ora-00060 deadlock detected while waiting for resource

模拟锁等待:

   两个事务a和b,分别创建t1,t2,并且初始化一条数据,

   a 更改t1的数据,此时并不提交,这时候b更改相同的一列,此时b一直处于等待的状态

我们可以查询锁等待的内容:

wait_lock.sql

select
      (select username from v$session where sid = a.sid) username,
      a.sid,
      (select serial# from v$session where sid = a.sid) serial#,
      a.type,
      a.id1,
      a.id2,
      a.lmode,
      a.request,
      a.block,
      b.sid blocking_sid
from v$lock a,
      ( select * from v$lock
        where request > 0
        and type <> 'MR'
      ) b
where a.id1 = b.id1(+)
   and a.id2 = b.id2(+)
   and a.lmode > 0
   and a.type <> 'MR'
order by username,a.sid,serial#,a.type

此时可以查询到锁等待的现象,最后一列不为空的就是等待的事件

此时我们可以跟a用户提示让其提交事务或是回滚,也可以直接杀死

alter system kill session 'sid,serial#';

保持现状不动,在a事务更改t2表此时在a事务会产生

SQL> update t1 set id=1000 where id=1;
update t1 set id=1000 where id=1
        *
第 1 行出现错误:
ORA-00060: 等待资源时检测到死锁

此时oracle已经帮我解决了这个死锁问题

死锁的产生需要四个必须的条件:

1 ,mutual execution(互斥)资源不能被共享,只能由一个进程使用

2,hold and wait(请求并持续)已经得到资源的进程可以再次申请新的资源

3,no pre-emption(不可剥夺)已经分配的资源不能被相应的进程强制剥夺

4,circular wait(循环等待条件)系统中若干进程组成环路,该环路中的每个进程都在等待相邻进程正占用的资源

定位死锁:

  系统级别的定位

    Select username,lockwait,status,machine,program from v$session where sid in (select session_id from v$locked_object)

      Username死锁的用户,lockwait死锁的状态,status中active表示死锁,machine死锁所在的机器,program死锁来自于那个程序

   语句级别的定位

      Select sql_text from v$sql where hash_value in (select sql_hash_value from v$session where sid in (select session_id from v$locked_object));

  进程级别的定位

   Select s.username,l.object_id,l.session_id,s.serial#,l.oracle_usrename,l.os_user_name,l.process from v$locked_object l,v$session s where l.session_id=s.sid;

处理死锁的一般策略

   1,鸵鸟算法忽略该问题

   2,定位死锁并且恢复

  3,仔细对资源进行动态分配,避免死锁

   4,破坏死锁中的一个条件

如果oracle解决不了的死锁,我们需要定位到进程级别,找到对应的sid和serial#

alter system kill 'sid,serail#'

失败的话,找到对应的进程强制关闭

Select p.spid from v$session s, v$process p where s.sid=xx and s.paddr=p.addr

ps -ef | grep spid

kill -9 xx



查询oracle的死锁

lock.sql

SELECT    bs.username "Blocking User", bs.username "DB User",
           ws.username "Waiting User", bs.SID "SID", ws.SID "WSID",
           bs.serial# "Serial#", bs.sql_address "address",
           bs.sql_hash_value "Sql hash", bs.program "Blocking App",
           ws.program "Waiting App", bs.machine "Blocking Machine",
           ws.machine "Waiting Machine", bs.osuser "Blocking OS User",
           ws.osuser "Waiting OS User", bs.serial# "Serial#",
           ws.serial# "WSerial#",
           DECODE (wk.TYPE,
                   'MR', 'Media Recovery',
                   'RT', 'Redo Thread',
                   'UN', 'USER Name',
                   'TX', 'Transaction',
                   'TM', 'DML',
                   'UL', 'PL/SQL USER LOCK',
                   'DX', 'Distributed Xaction',
                   'CF', 'Control FILE',
                   'IS', 'Instance State',
                   'FS', 'FILE SET',
                   'IR', 'Instance Recovery',
                   'ST', 'Disk SPACE Transaction',
                   'TS', 'Temp Segment',
                   'IV', 'Library Cache Invalidation',
                   'LS', 'LOG START OR Switch',
                   'RW', 'ROW Wait',
                   'SQ', 'Sequence Number',
                   'TE', 'Extend TABLE',
                   'TT', 'Temp TABLE',
                   wk.TYPE
                  ) lock_type,
           DECODE (hk.lmode,
                   0, 'None',
                   1, 'NULL',
                   2, 'ROW-S (SS)',
                   3, 'ROW-X (SX)',
                   4, 'SHARE',
                   5, 'S/ROW-X (SSX)',
                   6, 'EXCLUSIVE',
                   TO_CHAR (hk.lmode)
                  ) mode_held,
           DECODE (wk.request,
                   0, 'None',
                   1, 'NULL',
                   2, 'ROW-S (SS)',
                   3, 'ROW-X (SX)',
                   4, 'SHARE',
                   5, 'S/ROW-X (SSX)',
                   6, 'EXCLUSIVE',
                   TO_CHAR (wk.request)
                  ) mode_requested,
           TO_CHAR (hk.id1) lock_id1, TO_CHAR (hk.id2) lock_id2,
           DECODE
              (hk.BLOCK,
               0, 'NOT Blocking',          /**//* Not blocking any other processes */
               1, 'Blocking',              /**//* This lock blocks other processes */
               2, 'Global',           /**//* This lock is global, so we can't tell */
               TO_CHAR (hk.BLOCK)
              ) blocking_others
      FROM v$lock hk, v$session bs, v$lock wk, v$session ws
     WHERE hk.BLOCK = 1
       AND hk.lmode != 0
       AND hk.lmode != 1
       AND wk.request != 0
       AND wk.TYPE(+) = hk.TYPE
       AND wk.id1(+) = hk.id1
       AND wk.id2(+) = hk.id2
       AND hk.SID = bs.SID(+)
       AND wk.SID = ws.SID(+)
       AND (bs.username IS NOT NULL)
       AND (bs.username <> 'SYSTEM')
       AND (bs.username <> 'SYS')
ORDER BY 1;

这些语句的执行最好是在plsql或是sqldeveloper如果是直接在数据库里面执行的需要格式化表,否则会很让你眼花的。
分享到:
评论

相关推荐

    Oracle表死锁与解锁

    Oracle数据库在运行过程中,可能会遇到一种情况,那就是“表死锁”,这会导致多个事务相互等待对方释放资源,从而无法继续执行。死锁不仅影响数据库的正常运行,还可能导致数据一致性问题。本文将深入探讨Oracle表...

    查询ORACLE死锁以及解锁语句

    查询ORACLE死锁以及解锁语句查询ORACLE死锁以及解锁语句

    oracle死锁原因解决办法

    这个图展示了资源的持有者(Blocker)和等待者(Waiter)之间的关系,有助于理解死锁的具体情况。 #### 四、解决Oracle死锁的方法 ##### 4.1 优化SQL语句 确保所有事务中的SQL语句按照相同的顺序执行可以减少死锁...

    oracle解锁,死锁

    在深入讨论Oracle解锁和死锁之前,我们首先需要了解Oracle数据库中的锁机制。 1. **共享锁(S)**:允许多个用户读取行,但不允许修改。 2. **排他锁(X)**:允许单个用户修改行,其他用户只能等待。 3. **共享更新锁...

    oracle死锁表后处理

    oracle死锁表后处理是数据库管理员和开发人员需要掌握的重要技能,旨在解决oracle数据库中出现的死锁问题,确保数据的一致性和安全性。 oracle锁机制可以分为六种模式:none、null、Row-S、Row-X、Share、...

    oracle-死锁查询

    oracle死锁问题查询代码,仅供参考,有问题大家一起交流

    oracle查询死锁语句

    oracle查询死锁语句,并能根据根据ID值杀死锁表的进程!

    有效关闭Oracle死锁进程,和释放状态为killed的session

    在Oracle数据库管理中,处理死锁进程和释放状态为killed的session是一项关键技能,尤其对于维护数据库性能和稳定性至关重要。以下将详细阐述如何通过一系列步骤有效地关闭Oracle死锁进程,以及如何释放状态为killed...

    oracle死锁故障分析和诊断解决

    3. **使用死锁检测和自动解决机制**:Oracle提供了死锁检测功能,一旦检测到死锁,系统会自动选择牺牲其中一个事务,解决死锁。 4. **优化SQL语句**:合理使用SQL提示(如`/*+ NO_MERGE */`),减少不必要的全表扫描...

    Oracle 死锁问题的排查语句

    Oracle 死锁问题的排查语句 Oracle 死锁是指在数据库中出现的循环等待资源的情形,从而导致数据库性能下降或系统崩溃。出现死锁的原因有多种,如资源竞争、锁定机制不当等。下面是排查 Oracle 死锁问题的语句: 1....

    BLOG_Oracle_lhr_Oracle死锁的分类及其模拟.pdf

    此外,还应知道如何查看和分析Oracle的死锁跟踪文件,以便于诊断和解决实际遇到的死锁问题。 注意,本文的完整代码、相关资料和PDF版本可在作者提供的链接中找到,同时在多个平台有同步更新,便于读者根据自己的...

    解决ORACLE死锁问题

    一、数据库死锁的现象 程序在执行的过程中,点击确定或保存按钮,程序没有响应,也没有出现报错。 二、死锁的原理 当对于数据库某个表的某一列做更新或删除等操作,执行完毕后该条语句不提 交,另一条对于这一列...

    解决oracle死锁

    在Oracle数据库系统中,死锁是指两个或多个事务在执行过程中,因争夺资源而造成的一种相互等待的现象。当这种情况发生时,如果没有外部干预,这些事务将无法继续执行,因为它们都在等待对方释放资源。本篇将详细介绍...

    杀死oracle死锁进程

    解决Oracle数据库死锁问题,查询出数据库所有死锁,并杀死所有的死锁,解决程序运行问题;

    Oracle查询死锁表

    本文将围绕“Oracle查询死锁表”的主题展开详细讨论,旨在帮助数据库管理员更好地理解和掌握如何检测及解除Oracle中的死锁现象。 ### 一、理解Oracle死锁 #### 1.1 定义 死锁通常发生在两个或更多的事务试图同时...

    ORA-00060: 等待资源时检测到死锁--oracle 数据库表死锁异常

    在Oracle数据库系统中,"ORA-00060: 等待资源时检测到死锁" 是一个常见的错误提示,它表明两个或多个事务在执行过程中陷入了无法继续进行的状态,因为彼此都在等待对方释放资源。这种情况通常发生在并发操作中,比如...

    查询Oracle是否有死锁及解锁

    执行查询语句查询Oracle是否有死锁,以及叫你如何解锁。

    解决Oracle死锁问题.txt

    编译的存储过程的时候,程序死住,等待一会出现ora-04021错误解决办法。文档中有查询思索的语句,以及杀掉死锁进程的方法。

Global site tag (gtag.js) - Google Analytics