当前位置: 首页 > 图文教程 > 数据库 > Oracle > 如何解决Oracle被锁定问题

Oracle
Oracle数据库技术(32)
Oracle数据库技术(33)
Oracle数据库技术(34)
Oracle数据库技术(35)
Oracle数据库技术(36)
Oracle数据安全面面观
Oracle数据操作和控制语言详解
Oracle数据库数据对象分析
解析Oracle 8i/9i的计划稳定性
使用Oracle实现实时通信
Oracle数据库中索引的维护
Oracle数据库游标使用大全
Oracle9i中监视索引的使用
在Oracle9i中使用多种Block Size
监控Oracle数据库的常用shell脚本
Performance Improvement Tips for Oracle on UNIX
Raw Partitions and Windows NT
How to use OS commands to diagnose Database Performance issues?
Raw Devices and Oracle - 20 Common Questions and Answers
Monitor Oracle Resource Consumption in UNIX

如何解决Oracle被锁定问题


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-30   浏览: 64 ::
收藏到网摘: n/a

一些性能方面的告警信息通过dba_outstanding_alerts表都能查到,被锁定的表如果长期得不到释放,在这里也能查到相关session的sid和serial#。


  select * from dba_outstanding_alerts

  v$locked_object视图可以看到当前被锁定的对象,只有那些一直存在的session才有可能是被锁定的,因此不能简单匆忙的下结论,尤其是在RAC环境中,必须查看各个节点以发现相关的session在哪里。


  select * from v$locked_object

  有时候也可以根据对象名来查看锁的信息:


  select sid,id1,type from v$lock where id1=(select object_id from dba_objects where object_name=upper('mytablename'));

  找到了引起锁定的session,就可以找到对应的sid和serial#


  select saddr,sid,serial#,paddr,username,status from v$session where sid=772

  从而可以杀死这个session:


  SQL> alter system kill session '772,9044';
  System altered.

  可以查询Oracle数据库的进程和操作系统进程之间的关联:


  select spid, osuser, s.program from v$session s,v$process p
  where s.paddr=p.addr and s.sid=772

  有时候一些进程要在操作系统杀死,这时可以用kill -9 pid的命令:


  [root@erpdevdb ~]# ps -ef|grep sqlplus
  oracle 11847 11126 0 16:39 pts/1 00:00:00 sqlplus -S @/oracle/home/droptable.sql
  root 11889 11856 0 16:40 pts/2 00:00:00 grep sqlplus
  [root@erpdevdb ~]# kill -9 11847

  数据库对象锁定引起的阻塞是比较麻烦的事情,处理的时候一定要小心谨慎。