麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > Oracle > 正文

oracle ORA-00031:session marked for kill(標記要終止的會話)解決方法

2024-08-29 13:58:34
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了oracle ORA-00031:session marked for kill(標記要終止的會話)解決方法 ,需要的朋友可以參考下
 

今天碰到一個問題,有一張表不能操作,很可能是被鎖了,首先想到的是kill session,于是執行了下列的腳本找到是哪個session有問題:

查看表是否被鎖

SELECT /*+ rule*/a.sid, b.owner, object_name, object_typeFROM v$lock a, all_objects bWHERE TYPE = 'TM'and a.id1 = b.object_id;

根據上面查詢出的sid,找出對應的serial#:
SELECT sid,serial# FROM v$session WHERE sid = &sid;

發現有一個會話有鎖sid 197,serial# 17,于是執行alter system kill session ‘197,17';大概等了30s中,pl/sql developer報出一個錯誤:ora-00031:標記要終止的會話。

解決方法:查出session的spid

select spid, osuser, s.program from v$session s, v$process p where s.paddr = p.addr and s.sid =197;

1. 在linux上, kill -9 12345 
2. 在windows上,C:/Documents and Settings/gg>orakill orcl 12345

orcl:表示要殺死的進程屬于的實例名 
12345:是要殺掉的線程號

ORA-00031: session marked for kill 
Cause: The session specified in an ALTER SYSTEM KILL SESSION command cannot bekilled immediately (because it is rolling back or blocked on a networkoperation), but it has been marked for kill. This means it will be killed as soonas possible after its current uninterruptible operation is done.
Action: No action is required for the session to be killed, but further executionsof the ALTER SYSTEM KILL SESSION command on this session may cause the sessionto be killed sooner.

下面是補充:

oracle中編譯一個包的時候發現,只要一編譯就卡死了,后來使用《oracle查詢、Kill鎖資源的SQL語句》方法查鎖的時候發現包中用到的一些資源一直處于死鎖狀態。后來通過alter system kill session的方法去解鎖,卻發現出現如下圖1所示的問題:
ORA-00031:標記要終止的會話

ORA-00031:標記要終止的會話

后來通過連接上oracle數據庫所在的系統,然后kill掉進程解決,方法如下:

(1)查詢被鎖資源的sid、serial#:

SELECT s.sid,    s.serial#,    v.*,    ao.* FROM v$locked_object v,    all_objects   ao,    v$session    s WHERE v.object_id = ao.object_id  AND s.sid = v.session_id;

(2)利用上面的SQL查詢出sid和serial#以后,利用下面SQL去kill session:

-- 如有記錄則表示lock,記錄下SID和serial#,將記錄下的SID和serial#替換下面的738,1429,即可接觸lock。
ALTER SYSTEM KILL SESSION '738,1429';

(3)如果上面的kill session報如上圖1的錯誤,那么再用下面的SQL去查處session對應的spid:

SELECT p.spid,    s.osuser,    s.program FROM v$session s,    v$process p WHERE s.paddr = p.addr  AND s.sid = 37; -- 替換成相應的session_id

(4)連上oracle數據庫所在的系統(我這里是Linux系統),記錄下上面查到的spid(假設這里查到的是1133),然后使用下面語句來kill掉進程:

kill -9 1133

等待一會,等進程kill成功以后,再去查鎖即可發現資源已經被釋放。如果oracle安裝在Windows系統上,請使用Windows系統的kill進程的方式去殺掉進程。



注:相關教程知識閱讀請移步到oracle教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日本一区二区在线看 | 亚洲网站在线观看 | 久久综合久久美利坚合众国 | 49vvv| 国产精品成人久久久久a级 av电影在线免费 | 国产成人精品一区在线播放 | 亚洲一区二区不卡视频 | 亚洲一区二区在线 | 黄色国产在线观看 | 99精品国产小情侣高潮露脸在线 | 香蕉成人在线观看 | 青草久久av| 夜夜看 | 国产 日韩 亚洲 欧美 | 欧美成人小视频 | 日韩视频不卡 | 在线成人一区二区 | 91av网址 | 国产精品91在线 | 在线2区| 亚洲精品成人久久久 | 一区二区三区欧美在线 | 九九热视频在线免费观看 | 免费一级毛片电影 | 91香蕉国产亚洲一区二区三区 | 久久精品中文字幕一区二区 | 欧美一级成人一区二区三区 | 国内精品伊人久久久久网站 | 曰韩av在线 | 久久精热 | 久久久久国产成人免费精品免费 | 99热草 | 91在线精品亚洲一区二区 | 精品一区二区视频在线观看 | 强伦女教师视频 | 国产午夜免费不卡精品理论片 | 国产午夜亚洲精品理论片大丰影院 | 在线免费观看日韩视频 | 亚洲国产精品500在线观看 | 一级尻逼视频 | 亚洲视频综合网 |