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

2021-12-30 11:35:04 字數 1450 閱讀 1135

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

oracle資料庫管理人員經常會遇到這樣的問題:狀態已被置為"killed"的程序長時間鎖定系統資源不釋放。通常的做法是重啟資料庫,但這樣就以為著資料庫服務的中斷。這裡介紹另外一種好用方便的方法: 在作業系統級強行殺掉那些程序。 

www.2cto.com  

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

www.2cto.com  

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.在作業系統中殺掉相應的程序(執行緒): 

www.2cto.com  

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程序

經常會遇到乙個問題是 在oracle中,狀態已被置為 killed 的程序長時間鎖定系統資源,不釋放,有乙個比重啟資料庫更好的方法,就是在作業系統級強行殺掉那些程序。1.下面的語句用來查詢哪些物件被鎖 col object name for a30 col machine for a20 selec...

如何殺掉defunct程序

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

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