Oracle ORA-00060:Deadlock detected. More info in file /var/oracle/app/diag/rdbms/...记一次位图索引误用引发卡顿

Oracle ORA-00060:Deadlock detected. More info in file /var/oracle/app/diag/rdbms/…记一次位图索引误用带来的数据库卡顿死锁

数据库死锁带来的性能严重下降

生产环境客户端多发卡顿,排查Oracle日志后发现,数据库中有很多ORA-00060: Deadlock detected. More info in file /var/oracle/app/diag/rdbms/…xxx_ora_80471.trc 记录,初步判断是由资源死锁引起的数据库性能严重下降。

DEADLOCK DETECTED ( ORA-00060 )
 
[Transaction Deadlock]
 
The following deadlock is not an ORACLE error. It is a
deadlock due to user error in the design of an application
or from issuing incorrect ad-hoc SQL. The following
information may aid in determining the deadlock:
 
Deadlock graph:
                       ---------Blocker(s)--------  ---------Waiter(s)---------
Resource Name          process session holds waits  process session holds waits
TX-004f001a-0005a437       586     947     X            654    7339           S
TX-0028001d-000b2866       654    7339     X            586     947           S
 
session 947: DID 0001-024A-0000028F	session 7339: DID 0001-028E-00000012 
session 7339: DID 0001-028E-00000012	session 947: DID 0001-024A-0000028F 
 
Rows waited on:
  Session 947: obj - rowid = 0004FE8F - AABP6PAAAAAAAAAAAA
  (dictionary objn - 327311, file - 0, block - 0, slot - 0)
  Session 7339: obj - rowid = 0004FE8F - AABP6PAAAAAAAAAAAA
  (dictionary objn - 327311, file - 0, block - 0, slot - 0)
 
----- Information for the OTHER waiting sessions -----
Session 7339:
  sid: 7339 ser: 32541 audsid: 1484784475 user: 85/XXXXX(Oralce-User)
    flags: (0x8000045) USR/- flags_idl: (0x1) BSY/-/-/-/-/-
    flags2: (0x40009) -/-/INC
  pid: 654 O/S info: user: oracle, term: UNKNOWN, ospid: 83983
    image: oracle@localhost.localdomain
  client details:
    O/S info: user: ASP.NET v4.0, term: WIN-D74HSI9CPLM, ospid: 75884:77276
    machine: WORKGROUP\WIN-D74HSI9CPLM program: w3wp.exe
    application name: w3wp.exe, hash value=2799981571
  current SQL:
  UPDATE A(Oracle table) SET STATUS = :B5 ,................. WHERE ID = :B1 
 
----- End of information for the OTHER waiting sessions -----
 
Information for THIS session:
 
----- Current SQL Statement for this session (sql_id=g2vg0y4nyjkj3) -----
UPDATE A(Oracle table) SET STATUS = 'FINISHED', ................ WHERE ID = :B1 
----- PL/SQL Stack -----
----- PL/SQL Call Stack -----
  object      line  object
  handle    number  name
0x4b5bf89238       377  package body XXX.XXX(Oracle User.package Name)
0x4b5bf89238       399  package body XXX.XXX(Oracle User.package Name)
0x4ad9899c28         8  package body XXX.XXX(Oracle User.package Name)
0x4b7f6a2ab8         1  anonymous block
===================================================

从日志中可以看到是调用的存储过程执行更新状态字段事发生的死锁。

  current SQL:
  UPDATE A(Oracle table) SET STATUS = :B5 ,................. WHERE ID = :B1 

另外可以看到关键的资源等待信息:

Rows waited on:
  Session 947: obj - rowid = 0004FE8F - AABP6PAAAAAAAAAAAA
  (dictionary objn - 327311, file - 0, block - 0, slot - 0)
  Session 7339: obj - rowid = 0004FE8F - AABP6PAAAAAAAAAAAA
  (dictionary objn - 327311, file - 0, block - 0, slot - 0)

从这段代码可以看出,是在rowid为“0004FE8F - AABP6PAAAAAAAAAAAA”的对象资源发生的死锁。
使用

  select sys.dbms_rowid.rowid_object('0004FE8F - AABP6PAAAAAAAAAAAA') from dual;

获取对象id,从而获取对象名称信息

select *from sys.all_objects where  object_id = 'xxxxx'

得知引发死锁的是A表的位图索引I_xxx_status,删除此索引,死锁故障消失。
总结:
1.当发生大范围性能问题时,排查问题的首先应从数据库入手,分析Oracle的alter_xxx.log日志。
2.排除数据库级别的故障后,排查业务系统的性能,把执行耗时的业务逐个分析优化。
3.位图索引不能用于频繁更新值的字段。
4.当字段值域大于7个时,不能使用位图索引。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ORA-00060: deadlock detectedOracle数据库中的一个错误代码,它表示在等待资源时检测到了死锁。死锁是指两个或多个进程相互等待对方所持有的资源,导致系统无法继续进行下去。 这个错误通常与并发操作有关,其中至少有两个会话(或进程)试图同时访问相同的资源,但由于彼此之间的依赖关系,她们无法继续执行下去。 根据引用中的描述,当会话1执行UPDATE语句时,尝试更新id为2的录,但同时会话2也在等待并尝试更新id为1的录。由于两个会话互相依赖,并且需要等待对方释放资源,因此发生了死锁,导致其中一个会话被自动终止,并抛出ORA-00060错误。 要解决ORA-00060错误,可以采取以下措施: 1. 观察和录死锁事件的发生情况。可以使用Oracle提供的性能监视工具,如AWR报告或ADDM报告,来分析和识别频繁发生死锁的模式和原因。 2. 优化数据库设计和应用程序逻辑。检查数据库表和索引的设计,确保它们能够最小化并发操作引发死锁的可能性。同时,应用程序逻辑也需要考虑到并发访问资源的情况,避免出现相互依赖导致的死锁。 3. 使用适当的并发控制机制。可以使用Oracle提供的锁机制,如行级锁或表级锁,来管理并发操作。合理选择锁的粒度,避免不必要的锁竞争,减少死锁的概率。 4. 在发生死锁时,可以通过修改会话的事务隔离级别来解决问题。例如,将事务隔离级别设置为READ COMMITTED,以减少锁的范围,降低死锁风险。 总之,ORA-00060: deadlock detectedOracle数据库中一个常见的错误代码,表示在并发操作中检测到了死锁。通过观察和录死锁事件,优化数据库设计和应用程序逻辑,以及使用适当的并发控制机制,可以减少死锁的发生概率,并提高系统的性能和稳定性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值