Orcale解鎖腳本

在數(shù)據(jù)庫的開發(fā)過程中汗菜,經(jīng)常碰到包、存儲過程摧莽、函數(shù)無法編譯或編譯時會導致PL/SQL 無法響應的問題庙洼。碰到這種問題,基本上都要重啟數(shù)據(jù)庫解決镊辕,嚴重浪費開發(fā)時間油够。本文將就產(chǎn)生這種現(xiàn)象的原因和解決方案做基本的介紹。

問題分析

從事數(shù)據(jù)庫開發(fā)的都知道鎖的概念征懈,如:執(zhí)行 Update Table xxx Where xxx 的時候就會產(chǎn)生鎖石咬。這種常見的鎖在Oracle里面被稱為DML鎖。在Oracle中還有一種DDL鎖卖哎,主要用來保證存儲過程鬼悠、表結(jié)構(gòu)、視圖亏娜、包等數(shù)據(jù)庫對象的完整性焕窝,這種鎖的信息可以在DBA_DDL_LOCKS中查到。注意:V$LOCKED_OBJECT記錄的是DML鎖信息维贺,DDL鎖的信息不在里面它掂。
對應DDL鎖的是DDL語句,DDL語句全稱數(shù)據(jù)定義語句(Data Define Language)溯泣。用于定義數(shù)據(jù)的結(jié)構(gòu)或Schema虐秋,如:CREATE榕茧、ALTER、DROP客给、TRUNCATE用押、COMMENT、RENAME起愈。當我們在執(zhí)行某個存儲過程只恨、或者編譯它的時候Oracle會自動給這個對象加上DDL鎖译仗,同時也會對這個存儲過程所引用的對象加鎖抬虽。
了解了以上知識以后,我們可以得出結(jié)論:編譯包長時間無響應說明產(chǎn)生了死鎖纵菌。我們可以輕易的讓這種死鎖發(fā)生阐污,舉例:

  • 打開一個PL/SQL,開始調(diào)試某個函數(shù)(假設為:FUN_CORE_SERVICECALL)咱圆,并保持在調(diào)試狀態(tài)
    
  • 打開一個SQL Window笛辟,輸入Select *From dba_ddl_locks aWhere a.name ='FUN_CORE_SERVICECALL'會發(fā)現(xiàn)一行記錄:
    
  • 打開一個新的PL/SQL,重新編譯這個函數(shù)序苏。我們會發(fā)現(xiàn)此時已經(jīng)無法響應了
    
  • 回到第一個PL/SQL ,重新執(zhí)行Select *From dba_ddl_locks aWhere a.name ='FUN_CORE_SERVICECALL'我們將會看到如下記錄:
    
  • 上述的情況表明發(fā)生了鎖等待的情況手幢。
    

在Oracle中DDL鎖分為:Exclusive DDL Locks(排他的DDL)、Share DDL Locks(共享DDL鎖)忱详、Breakable Parse Locks(可被打破的解析鎖)幾類围来。篇幅所限,這里就不再詳細介紹了匈睁。根據(jù)這個例子推理一下监透,當我們試圖編譯、修改存儲過程航唆、函數(shù)胀蛮、包等對數(shù)據(jù)對象的時候,如果別人也正在編譯或修改他們時就會產(chǎn)生鎖等待糯钙;或者我們在編譯某個存儲過程的時候粪狼,如果它所引用的數(shù)據(jù)庫對象正在被修改應該也會產(chǎn)生鎖等待。這種假設有興趣的兄弟可以測試下任岸,不過比較困難再榄。

解決方案

碰到這種問題,如果知道是被誰鎖定了(可以查出來的)演闭,可以讓對方盡快把鎖釋放掉不跟;實在查不出來只能手工將這個鎖殺掉了。步驟如下:
1米碰、 首先查出哪些進程鎖住了這個對象窝革,語句如下:
Select b.SID,b.SERIAL#
Fromdba_ddl_locks a, v$session b
Where a.session_id= b.SID
And a.name ='FUN_CORE_SERVICECALL';
2购城、 執(zhí)行如下語句殺進程:alter system kill session 'sid,serial#'
3、 執(zhí)行了以上的語句后虐译,有的時候不一定能夠?qū)⑦M程殺掉瘪板。這個時候就需要連到數(shù)據(jù)庫服務器上殺掉服務器端的進程了,查詢語句:
Select spid, osuser, s.program
Fromv$session s, v$process p
Where s.paddr= p.addr
And s.sid =(上面查出來的SID)
4漆诽、 在服務器上執(zhí)行如下語句:
kill -9 spid(UNIX平臺)
orakill sid thread(Windows平臺SID是Oracle的實例名侮攀,thread是上面查出來的SID)
5、 執(zhí)行完4步以后基本上就可以殺掉這些鎖死的進程了厢拭,不放心的話可以再執(zhí)行第一步確認下兰英。
本文只能是說對這個問題做了初步分析,產(chǎn)生此問題的原因及解決方案涉及到很多Oracle的基本知識供鸠。如:DML語句畦贸,DDL語句;Oracle鎖的機制楞捂;v$session 與 v$process之間關系等薄坏。有興趣的兄弟可以更加深入的研究,歡迎跟我交流寨闹!

死鎖是數(shù)據(jù)庫經(jīng)常發(fā)生的問題胶坠,數(shù)據(jù)庫一般不會無緣無故產(chǎn)生死鎖,死鎖通常都是由于我們應用程序的設計本身造成的繁堡。產(chǎn)生死鎖時沈善,如何解決呢,下面是常規(guī)的解決辦法:

1)執(zhí)行下面SQL帖蔓,先查看哪些表被鎖住了:
select b.owner,b.object_name,a.session_id,a.locked_mode
from v$locked_object a,dba_objects b
where b.object_id = a.object_id;

2)查處引起死鎖的會話
select b.username,b.sid,b.serial#,logon_time
from v$locked_object a,v$session b
where a.session_id = b.sid order by b.logon_time;
這里會列出SID

3) 查出SID和SERIAL#:
查V$SESSION視圖:
SELECT SID,SERIAL#,PADDR FROM V$SESSION WHERE SID='剛才查到的SID';
這一步將得到PADDR

4)查V$PROCESS視圖:
SELECT SPID FROM V$PROCESS WHERE ADDR='剛才查到的PADDR';
這一步得到SPID

5)殺死進程
(1)在數(shù)據(jù)庫中矮瘟,殺掉ORACLE進程:
ALTER SYSTEM KILL SESSION '查出的SID,查出的SERIAL#';

執(zhí)行存儲過程更新一個表中的數(shù)據(jù)的時候產(chǎn)生如下的錯誤:

SQL> exec update_jc_kxx_yxrq;

begin update_jc_kxx_yxrq; end;

ORA-20998: Err=-2049,Msg=0-ORA-02049: 超時: 分布式事務處理等待鎖定
ORA-06512: 在"ICUSER.UPDATE_JC_KXX_YXRQ", line 36
ORA-06512: 在line 2

以sys用戶登陸數(shù)據(jù)庫查詢死鎖

SQL> select username,lockwait,status,machine,program from v$session where sid in
(select session_id from v$locked_object);

USERNAME LOCKWAIT STATUS


MACHINE

PROGRAM

icdb
JDBC Thin Client

ICUSER 000000038A37C0C8 ACTIVE
icdb
JDBC Thin Client

說明數(shù)據(jù)庫有死鎖

然后使用一下語句查找被死鎖的語句

SQL> select sql_text from v$sql where hash_value in
(select sql_hash_value from v$session where sid in
(select session_id from v$locked_object));

SQL_TEXT

update JC_KXX SET LJXF =NVL ( LJXF , 0 ) + :1 , YE =:2 WHERE KH =:3
update jc_kxx set zt='07' where kh='1000530330'

再使用以下語句查找被死鎖的進程

SQL> SELECT s.username,l.OBJECT_ID,l.SESSION_ID,s.SERIAL#,
l.ORACLE_USERNAME,l.OS_USER_NAME,l.PROCESS
FROM V$LOCKED_OBJECT l,V$SESSION S WHERE l.SESSION_ID=S.SID;

USERNAME OBJECT_ID SESSION_ID SERIAL#


ORACLE_USERNAME OS_USER_NAME PROCESS


ICUSER 30523 32 42463
ICUSER oracle

ICUSER 30523 28 25508
ICUSER oracle

ICUSER 30523 76 14781
ICUSER oracle

USERNAME OBJECT_ID SESSION_ID SERIAL#


ORACLE_USERNAME OS_USER_NAME PROCESS


ICUSER 30523 24 37522
ICUSER oracle

使用一下語句把死鎖的進程kill

alter system kill session ‘sid,serial#’; (其中sid=l.session_id)

如:SQL> alter system kill session '24,37522';

再次執(zhí)行存儲過程,錯誤沒有了塑娇。語句執(zhí)行成功澈侠!

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市埋酬,隨后出現(xiàn)的幾起案子哨啃,更是在濱河造成了極大的恐慌,老刑警劉巖写妥,帶你破解...
    沈念sama閱讀 221,430評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件拳球,死亡現(xiàn)場離奇詭異,居然都是意外死亡珍特,警方通過查閱死者的電腦和手機祝峻,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,406評論 3 398
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人莱找,你說我怎么就攤上這事酬姆。” “怎么了奥溺?”我有些...
    開封第一講書人閱讀 167,834評論 0 360
  • 文/不壞的土叔 我叫張陵辞色,是天一觀的道長。 經(jīng)常有香客問我浮定,道長相满,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,543評論 1 296
  • 正文 為了忘掉前任桦卒,我火速辦了婚禮立美,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘闸盔。我一直安慰自己悯辙,他們只是感情好琳省,可當我...
    茶點故事閱讀 68,547評論 6 397
  • 文/花漫 我一把揭開白布迎吵。 她就那樣靜靜地躺著,像睡著了一般针贬。 火紅的嫁衣襯著肌膚如雪击费。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,196評論 1 308
  • 那天桦他,我揣著相機與錄音蔫巩,去河邊找鬼。 笑死快压,一個胖子當著我的面吹牛圆仔,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蔫劣,決...
    沈念sama閱讀 40,776評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼坪郭,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了脉幢?” 一聲冷哼從身側(cè)響起歪沃,我...
    開封第一講書人閱讀 39,671評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎嫌松,沒想到半個月后沪曙,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,221評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡萎羔,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,303評論 3 340
  • 正文 我和宋清朗相戀三年液走,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,444評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡缘眶,死狀恐怖腻窒,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情磅崭,我是刑警寧澤儿子,帶...
    沈念sama閱讀 36,134評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站砸喻,受9級特大地震影響柔逼,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜割岛,卻給世界環(huán)境...
    茶點故事閱讀 41,810評論 3 333
  • 文/蒙蒙 一愉适、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧癣漆,春花似錦维咸、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,285評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至婚肆,卻和暖如春租副,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背较性。 一陣腳步聲響...
    開封第一講書人閱讀 33,399評論 1 272
  • 我被黑心中介騙來泰國打工用僧, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人赞咙。 一個月前我還...
    沈念sama閱讀 48,837評論 3 376
  • 正文 我出身青樓责循,卻偏偏與公主長得像,于是被迫代替她去往敵國和親攀操。 傳聞我的和親對象是個殘疾皇子院仿,可洞房花燭夜當晚...
    茶點故事閱讀 45,455評論 2 359

推薦閱讀更多精彩內(nèi)容