ORA-00031:session marked for kill(標記要終止的會話)解決方法
今天碰到一個問題,有一張表不能操作,很可能是被鎖了,首先想到的是kill session,於是執行了下列的指令碼找到是哪個session有問題:
檢視錶是否被鎖
SELECT /*+ rule*/
a.sid, b.owner, object_name, object_type
FROM v$lock a, all_objects b
WHERE 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:標記要終止的會話。
檢視錶是否被鎖
SELECT /*+ rule*/
a.sid, b.owner, object_name, object_type
FROM v$lock a, all_objects b
WHERE 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. 在上,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.
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/14663377/viewspace-1226186/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Alter system kill session and ORA-00031: session marked for killSession
- ORA-00031: 標記要刪去的會話,但會話kill不掉解決辦法會話
- [Oracle報錯處理]ORA-00031: session marked for killOracleSession
- ora-00031:session marked for kill處理oracle中殺不掉的鎖SessionOracle
- ORA-00031:session marked for kill處理oracle中殺不掉鎖的程式SessionOracle
- 【會話】Oracle kill session系列會話OracleSession
- oracle 會話(session)被鎖瞭解決方法Oracle會話Session
- kill session遇到ORA-00031錯誤Session
- 建立索引意外終止解決方法索引
- 批量kill殺死某些會話session的plsql會話SessionSQL
- AWS RDS for MySQL如何終止會話MySql會話
- mysqldump意外終止的原因以及解決方法MySql
- 終止程式的工具 kill 、killall、pkill、xkill
- kill session之後,會話一直無法釋放的巧妙解決辦法(lsof)Session會話
- 大話Oracle中的kill sessionOracleSession
- kill session V$SESSION標記為KILLED 的2種情況Session
- Kill session 和orakill 殺會話及程式總結Session會話
- 要 kill session 例子,session多,報錯如下Session
- ORA-00027: 無法終止當前會話會話
- 資料庫日誌中Immediate Kill Session錯誤解決方法資料庫Session
- Session會話Session會話
- Linux 下用ps查詢程式並用kill終止命令詳解Linux
- Kill會話過程分析會話
- Linux之ps查詢程式用kill終止命令Linux
- Cassandra的Session會話Session會話
- MySQL: kill 會話的實現原理MySql會話
- 根據v$session 之status及logon_time有選擇kill某些session會話SessionGo會話
- win10電腦藍屏終止程式碼memory management的解決方法Win10
- kill sessionSession
- 檢視當前會話session id方法:會話Session
- Oracle 會話(Session)Oracle會話Session
- MySQL kill會話不起作用?MySql會話
- Kill會話過程分析(二)會話
- 【kill session】Oracle 徹底 kill session(轉載)SessionOracle
- ORACLE快速徹底Kill掉的會話Oracle會話
- win10藍屏終止程式碼badpoolheader的最佳解決方法Win10Header
- MQTT 持久會話與 Clean Session 詳解MQQT會話Session
- 如何在Linux中使用Shell指令碼終止使用者會話?Linux指令碼會話