oracle数据库简易故障排查之死锁处理
来源:互联网 发布:ubuntu caffe cuda8.0 编辑:程序博客网 时间:2024/05/30 12:30
最近一个朋友说他的数据库好慢,而且一个ctx_ddl.sync_index(‘apps.tname’)的过程执行了一周还没执行完毕,也没有报错。开始的时候我以为是表空间的问题,但是因为没时间只是简单找了下,于是让他查下是否有死锁,在正式系统中一查,果然发现在开始执行全文索引同步的时候一个对apps.tname做了for update 操作,for update 会锁表,于是乎就这样等了一周。
有时候我们的存储过程执行很久,从日志又没办法确定这个存储过程是否正常的情况下,如何确定是否存在问题呢。
后面想了下日常执行一些存储过程或者数据库运行缓慢的时候除了收集AWR报告和看日志外,简易的处理方法,总结如下
1、查询数据库中有哪些锁
select t2.username,t2.sid,t2.serial#,t2.logon_time from v$locked_object t1,v$session t2 where t1.session_id=t2.sid order by t2.logon_time;
2、根据上面查询到的sid 查询具体执行的语句
select sql_text from v$session a,v$sqltext_with_newlines b where DECODE(a.sql_hash_value, 0, prev_hash_value, sql_hash_value)=b.hash_value and a.sid=&sid order by piece;
3、查询这些语句sql如果这些sql不重要,或者会产生死锁情况下,干掉不必要的sql
alter system kill session 'sid,serial#';4、如果无法正常结束可以再操作系统级别杀掉,一下是查找操作系统的进程号,根据sid查找到
select spid, osuser, s.program from v$session s,v$process p where s.paddr=p.addr and s.sid=$sid
5、在操作系统级别杀掉相应的进程。
orakill instance_name spid
1 0
- oracle数据库简易故障排查之死锁处理
- ORACLE死锁(ORA-00060)故障排查的一般性手法
- Oracle数据库死锁处理
- [Oracle] ORACLE死锁故障排查的一般性手法的备忘录/分析死锁日志
- Oracle数据库系统紧急故障处理方法
- Oracle数据库 ORA-600 [13013]故障处理
- Oracle数据库死锁问题探讨与处理
- Oracle数据库的死锁查看与处理
- JDK内置故障处理&排查工具
- 关于数据库index_merge引发的死锁排查
- 故障排查
- PHP服务故障排查之路
- 一次ORA-60死锁故障的处理
- 张乐奕:如何成为oracle ACE及数据库故障处理感受
- Oracle数据库监听非常慢,基本hang住故障处理
- ORACLE故障处理
- 数据库故障处理
- 数据库故障处理
- 写给自己
- sql语句生成javabean类
- 在.NET中利用XMLHTTP下载文件
- LeetCode No.11 ~No.12
- Android状态栏微技巧,带你真正理解沉浸式模式
- oracle数据库简易故障排查之死锁处理
- java中final用在参数中表示什么?
- Android 省市县 三级联动(android-wheel的使用)
- STL源码剖析
- 间隔像素相等 图片显示距离不相等
- Delphi 中获取文件大小
- Linux网络编程 - TCP高级应用:socket文件描述符属性控制
- [经典]差不多先生传
- C++生成不重复的随机数