轻松接触Oracle数据库中的Kill session
2007-09-12 12:38:53 来源:WEB开发网核心提示:问:当一个session被kill掉以后,该session的paddr被修改,轻松接触Oracle数据库中的Kill session,如果有多个session被kill,那么多个session的paddr都会被更改为相同的进程地址,那么马上会收到进程中断的提示,process退出,在这种情况下,资源是无法释放的,我选择
问:当一个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。
- ››oracle 恢复误删除的表和误更新的表
- ››Oracle分页查询排序数据重复问题
- ››Oracle创建dblink报错:ORA-01017、ORA-02063解决
- ››Oracle 提高SQL执行效率的方法
- ››轻松清理Windows7系统记录技巧4则
- ››轻松清理 Win7记录4则技巧
- ››Oracle 动态查询,EXECUTE IMMEDIATE select into...
- ››Oracle 11g必须开启的服务及服务详细介绍
- ››oracle性能34条优化技巧
- ››oracle数据库生成随机数的函数
- ››Oracle 数据库表空间容量调整脚本
- ››oracle单库彻底删除干净的方法
更多精彩
赞助商链接