ORACLE殺掉沒有釋放的的sql程序

2021-09-01 13:12:18 字數 1357 閱讀 5613

如何完全殺掉帶鎖的程序並釋放資源

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...