oracle死锁及处理方式.docx
上传人:sy****28 上传时间:2024-09-13 格式:DOCX 页数:25 大小:92KB 金币:14 举报 版权申诉
预览加载中,请您耐心等待几秒...

oracle死锁及处理方式.docx

oracle死锁及处理方式.docx

预览

免费试读已结束,剩余 15 页请下载文档后查看

14 金币

下载此文档

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

Oracle死锁查询及处理关于数据库死锁的检查方法一、数据库死锁的现象程序在执行的过程中,点击确定或保存按钮,程序没有响应,也没有出现报错。二、死锁的原理当对于数据库某个表的某一列做更新或删除等操作,执行完毕后该条语句不提交,另一条对于这一列数据做更新操作的语句在执行的时候就会处于等待状态,此时的现象是这条语句一直在执行,但一直没有执行成功,也没有报错。三、死锁的定位方法通过检查数据库表,能够检查出是哪一条语句被死锁,产生死锁的机器是哪一台。1)用dba用户执行以下语句selectusername,lockwait,status,machine,programfromv$sessionwheresidin(selectsession_idfromv$locked_object)如果有输出的结果,则说明有死锁,且能看到死锁的机器是哪一台。字段说明:Username:死锁语句所用的数据库用户;Lockwait:死锁的状态,如果有内容表示被死锁。Status:状态,active表示被死锁Machine:死锁语句所在的机器。Program:产生死锁的语句主要来自哪个应用程序。2)用dba用户执行以下语句,可以查看到被死锁的语句。selectsql_textfromv$sqlwherehash_valuein(selectsql_hash_valuefromv$sessionwheresidin(selectsession_idfromv$locked_object))四、死锁的解决方法一般情况下,只要将产生死锁的语句提交就可以了,但是在实际的执行过程中。用户可能不知道产生死锁的语句是哪一句。可以将程序关闭并重新启动就可以了。经常在Oracle的使用过程中碰到这个问题,所以也总结了一点解决方法。1)查找死锁的进程:sqlplus"/assysdba"(sys/change_on_install)SELECTs.username,l.OBJECT_ID,l.SESSION_ID,s.SERIAL#,l.ORACLE_USERNAME,l.OS_USER_NAME,l.PROCESSFROMV$LOCKED_OBJECTl,V$SESSIONSWHEREl.SESSION_ID=S.SID;2)kill掉这个死锁的进程:altersystemkillsession‘sid,serial#’;(其中sid=l.session_id)3)如果还不能解决:selectpro.spidfromv$sessionses,v$processprowhereses.sid=XXandses.paddr=pro.addr;其中sid用死锁的sid替换:exitps-ef|grepspid其中spid是这个进程的进程号,kill掉这个Oracle进程from:http://southking.javaeye.com/blog/550832selectA.SQL_TEXT,B.USERNAME,C.OBJECT_ID,C.SESSION_ID,B.SERIAL#,C.ORACLE_USERNAME,C.OS_USER_NAME,C.Process,''''||C.Session_ID||','||B.SERIAL#||''''fromv$sqlA,v$sessionB,v$locked_objectCwhereA.HASH_VALUE=B.SQL_HASH_VALUEandB.SID=C.Session_IDoracle死锁解决办法1.查哪个过程被锁查V$DB_OBJECT_CACHE视图:SELECT*FROMV$DB_OBJECT_CACHEWHEREOWNER='过程的所属用户'ANDLOCKS!='0';2.查是哪一个SID,通过SID可知道是哪个SESSION.查V$ACCESS视图:SELECT*FROMV$ACCESSWHEREOWNER='过程的所属用户'ANDNAME='刚才查到的过程名';3.查出SID和SERIAL#查V$SESSION视图:SELECTSID,SERIAL#,PADDRFROMV$SESSIONWHERESID='刚才查到的SID'查V$PROCESS视图:SELECTSPIDFROMV$PROCESSWHEREADDR='刚才查到的PADDR';4.杀进程(1).先杀ORACLE进程:ALTERSYSTEMKILLSESSION'查出的SID,查出的SERIAL#';HYPERLINK"http://bbs.examda.com/"考试大论坛(2).能过CMD控制台,再杀操作系统进程:ORA