如何完全殺掉帶鎖的程序並釋放資源
oracle資料庫管理人員經常會遇到這樣的問題:狀態已被置為"killed"的程序長時間鎖定系統資源不釋放。通常的做法是重啟資料庫,但這樣就以為著資料庫服務的中斷。這裡介紹另外一種好用方便的方法: 在作業系統級強行殺掉那些程序。
1.下面的語句用來查詢哪些物件被鎖:
sql> col object_name for a30
sql> col machine for a20
sql> select object_name,machine,s.sid,s.serial#
from v$locked_object l,dba_objects o ,v$session s
where l.object_id = o.object_id and l.session_id=s.sid;
2.下面的語句用來殺死乙個程序:
sql> alter system kill session '42,21993'; (其中24,111分別是上面查詢出的sid,serial#)
可以用如下查詢批量得到上面類似的語句:
sql> select 'alter system kill session '''||s.sid||','||s.serial#||'''; '
from v$locked_object l,dba_objects o ,v$session s
where l.object_id = o.object_id and l.session_id=s.sid;
3.如果利用上面的命令殺死乙個程序後,程序狀態被置為 "killed", 但是鎖定的資源很長時間沒有被釋放,那麼可以在os一級再殺死相應的程序(執行緒),首先獲得程序(執行緒)號:
sql> select spid, osuser, s.program
from v$session s,v$process p
where s.paddr=p.addr and s.sid=#sid; (#sid是上面的sid)
4.在作業系統中殺掉相應的程序(執行緒):
1)在linux上,用root身份執行命令:
$ kill -9 12345 (12345是第3步查詢出的spid)
2)在windows 用orakill殺死執行緒,orakill是oracle提供的乙個可執行命令,語法為:orakill sid thread
sid:表示要殺死的程序屬於的例項名
thread:是要殺掉的執行緒號,即第3步查詢出的spid
例:c:\> orakill orcl 12345
完全可以寫乙個組合查詢的儲存過程來自動執行上述四步操作,方便地殺光所有不自動釋放資源的程序,但一般情況下不推薦這樣做,畢竟在系統中用root使用者kill程序本身就是帶有一定風險的!
ORACLE殺掉沒有釋放的的sql
oracle殺掉沒有釋放的的sql程序分類 資料庫 mysql 文章 如何完全殺掉帶鎖的程序並釋放資源 oracle資料庫管理人員經常會遇到這樣的問題 狀態已被置為 killed 的程序長時間鎖定系統資源不釋放。通常的做法是重啟資料庫,但這樣就以為著資料庫服務的中斷。這裡介紹另外一種好用方便的方法 ...
殺掉oracle的死鎖
關閉oracle死鎖程序的具體步驟 有效關閉oracle死鎖程序的具體步驟 查哪個過程被鎖 查v db object cache檢視 select from v db object cache where owner 過程的所屬使用者 and locks 0 2.查是哪乙個sid,通過sid可知道是...
殺掉ORACLE會話的步驟
1.檢視被鎖的物件 select b.object name,machine,c.sid,c.serial b.status,d.pid,d.spid,d.addr from locked object a,dba objects b,session c,v process d where a.ob...