• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    oracle 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:标记要终止的会话。

    解决方法:查出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中查看引起Session阻塞的2个脚本分享
    • Oracle中的Connect/session和process的区别及关系介绍
    • ORACLE 如何查询被锁定表及如何解锁释放session
    • 对于oracle对session进行跟踪的分析
    上一篇:Linux下Oracle删除用户和表空间的方法
    下一篇:Oracle中查看引起Session阻塞的2个脚本分享
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    oracle ORA-00031:session marked for kill(标记要终止的会话)解决方法 oracle,ORA-00031,session,marked,