科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道轻松接触Oracle数据库中的Kill session

轻松接触Oracle数据库中的Kill session

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

当一个session被kill掉以后,该session的paddr被修改,如果有多个session被kill,那么多个session的paddr都会被更改为相同的进程地址,在这种情况下,资源是无法释放的,我选择了查询spid

作者:陈靖 来源:赛迪网 2007年9月20日

关键字: session KILL process spid

  • 评论
  • 分享微博
  • 分享邮件

问:当一个session被kill掉以后,该session的paddr被修改,如果有多个session被kill,那么多个session的paddr都会被更改为相同的进程地址,在这种情况下,资源是无法释放的,我选择了查询spid,在操作系统级来kill这些进程。但是由于此时v$session.paddr已经改变,我已经无法通过v$session和v$process关联来获得spid,那还可以怎么办呢?

答:具体示例如下:

SQL> select p.addr from v$process p where pid 
<> 1  2  minus  3  select s.paddr from v$session s; 
ADDR 
-------- 
542B70E8 
542B7498

现在我们获得了进程地址,就可以在v$process中找到spid,然后可以使用Kill或者orakill在系统级来杀掉这些进程。

当在Oracle中kill session以后, Oracle只是简单的把相关session的paddr 指向同一个虚拟地址.

此时v$process和v$session失去关联,进程就此中断,然后Oracle就等待PMON去清除这些Session.所以通常等待一个被标记为Killed的Session退出需要花费很长的时间,如果此时被Kill的process,重新尝试执行任务,那么马上会收到进程中断的提示,process退出,此时Oracle会立即启动PMON 来清除该session

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章