Oracle中Session连接数超过上限值

        某进程处理数据失败,导致Session连接无法正常断开,如果此进程频繁操作数据,会导致Oracle系统的Session连接数超出了默认的上限值150。

具体处理方法:

       1、创建一个存储过程,用于定时删除产生异常而不能正常断开的Session。

    PROCEDURE KILL_SESSION
    IS
        V_SQL_STR       VARCHAR2 (300);
    BEGIN
        FOR T IN (SELECT SID, USERNAME, PADDR, STATUS, serial# FROM V$SESSION
                         WHERE USERNAME = 'USER_ABC' AND STATUS IN ('INACTIVE', 'KILLED')
                         AND UPPER(PROGRAM) = '某进程.EXE' AND LOGON_TIME < SYSDATE - 20/1440)
        LOOP
            V_SQL_STR := 'ALTER SYSTEM KILL SESSION ''' || T.SID || ',' || T.SERIAL# || ''' IMMEDIATE';
            EXECUTE IMMEDIATE V_SQL_STR;
        END LOOP;
    END KILL_SESSION;


        2、新建一个job定时去执行就可以了。

        通过这种方法,可以把Oracle中Session状态为Inactive和Killed直接终止掉。

        (注:这里的连接时间我设置为20分钟。执行Kill Session操作一般会经历两个阶段,首先INACTIVE会变为KILLED。此时不处理,Session很难被系统回收掉。所以

                    再执行一次Kill操作,则可以将加速处理死锁和回滚。)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值