如何殺掉帶鎖的oracle程序

2021-09-27 05:47:26 字數 1273 閱讀 1678

經常會遇到乙個問題是:在oracle中,狀態已被置為"killed"的程序長時間鎖定系統資源,不釋放,有乙個比重啟資料庫更好的方法,就是在作業系統級強行殺掉那些程序。

1.下面的語句用來查詢哪些物件被鎖:

col object_name for a30

col machine for a20

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.下面的語句用來殺死乙個程序:

alter system kill session '42,21993'; (其中24,111分別是上面查詢出的sid,serial#)

可以用如下查詢批量得到上面類似的語句:

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一級再殺死相應的程序(執行緒),首先獲得程序(執行緒)號:

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資料庫管理人員經常會遇到這樣的問題 狀態已被置為 killed 的程序長時間鎖定系統資源不釋放。通常的做法是重啟資料庫,但這樣就以為著資料庫服務的中斷。這裡介紹另外一種好用方便的方法 在作業系統級強行殺掉那些程序。www.2cto.com 1.下面的語句...

Oracle 檢視 殺掉鎖表程序

檢視鎖表程序sql語句1 select sess.sid,sess.serial lo.oracle username,lo.os user name,ao.object name,lo.locked mode from v locked object lo,dba objects ao,v ses...

如何殺掉defunct程序

在unix系統管理中,當用ps命令觀察程序的執行狀態時,經常看到某些程序的狀態列為defunct,這就是所謂的 殭屍 程序。殭屍 程序是乙個早已死亡的程序,但在程序表 processstable 中仍佔了乙個位置 slot 由於程序表的容量是有限的,所以,defunct程序不僅占用系統的記憶體資源,...