文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

oracle什么时候才回收v$session中status='KILLED'的进程

2023-06-06 02:57

关注

本篇文章为大家展示了oracle什么时候才回收v$session中status='KILLED'的进程,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

oracle 什么时候才回收v$session 中status='KILLED'的进程,有些进程被杀掉之后一直没有被回收

session需要释放它所使用的资源,包括锁,回滚段等资源;如果session已经运行了很长时间,kill session 可能是一个非常消耗时间的过程

察看session目前使用的回滚段块的数目信息
SELECT USED_UBLK FROM V$TRANSACTIOn a ,v$session b where a.addr=b.taddr;

你可以看看要回滚的数量
1.判断是否在回滚
select * from V$TRANSACTIOn where bitand(flag,power(2,7))>0
flag字段值可以标识事务类型
select to_char( 7811, '0000000X' ), to_char( 7683, '0000000X') from dual;

TO_CHAR(7 TO_CHAR(7
--------- ---------
00001E83  00001E03
      ^           ^
0 indicates "normal user transaction"
8 indicates "rollback,most likely - means no more changes and you cannot commit"

2.回滚量:UBABLK字段
3.查看回滚时间
col td format a40
col es format 999,999
col totalwork format 999,999
col units format a10
SELECT  decode(target_desc,NULL,decode(target,NULL,opname, concat(opname, concat (' - ',target))),decode(target,NULL,concat(opname, concat (' : ',target_desc)),concat(opname, concat (' : ',concat(target_desc,concat (' - ',target)))))) td,sofar,totalwork,units,start_time,TO_CHAR(elapsed_seconds,'99999990.00'), decode(sofar, 0, 0, round(elapsed_seconds*(totalwork-sofar)/sofar))  剩下的时间

FROM v$session_longops

WHERE sid = &v_sid

AND serial# =&v_serial#

and sofar< totalWork
D                                    SOFAR TOTALWORK UNITS    START_TIME  TO_CHAR(ELAPSED_SECONDS,'99999         剩下的时间
------------------------------------      ----- --------- -------- ----------- ------------------------------      ----------
Table Scan - SINO.ACC_POENTRYD        16099     16099 Blocks   2005-4-15 1         8.00                            0查看剩下的时间
4.你使用了alter session kill一个死进程,可能当时只是把session标识了killed,而v$process还存在,你可以用下面方法解决
UNIX平台
SQL>  SELECT spid
                FROM v$process
                WHERE NOT EXISTS ( SELECT 1
                                   FROM v$session
                                   WHERE paddr = addr);

      % kill
WINDOWS:
      select p.spid "OS Thread", b.name "Name-User", s.osuser,
               s.program              
         from v$process p, v$session s, v$bgprocess b                                
            where p.addr = s.paddr                                                    
               and p.addr = b.paddr
      UNION ALL                                            
                select p.spid "OS Thread", s.username "Name-User",
                         s.osuser, s.program
                   from v$process p, v$session s                                      
                      where p.addr = s.paddr                                          
                      and s.username is not null;    使用orakill如
SQL> SELECT spid, osuser, s.program,sid
                FROM v$process p, v$session s
                WHERE p.addr=s.paddr;
SPID                     OSUSER               PROGRAM                SID
------------------------ -------------------- --------------- ----------
6484                     lifeng.fang          sqlplus.exe             11
SQL> host orakill charset 6484;

Kill of thread id 6484 in instance charset successfully signalled.
5.你可以在sqlnet.ora加dcd

上述内容就是oracle什么时候才回收v$session中status='KILLED'的进程,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯