1、启动资源计划

alter system set resource_limit=true scope=spfile;

2、设置非活动回话十五分钟断开,释放资源

alter profile default limit idle_time 15;

3.  清楚非活动的进程 (没10分钟发送检测包)

$ORACLE_HOME/network/admin 添加 SQLNET.EXPIRE_TIME=10;

  1. SELECT SID, SERIAL#,MODULE, STATUS
  1. FROM V$SESSION S
  1. WHERE S.USERNAME ISNOTNULL
  1. ANDUPPER(S.PROGRAM) IN ('TOAD.EXE', 'W3WP.EXE')
  1. AND S.LAST_CALL_ET >= 60*60*2
  1. AND S.STATUS = 'INACTIVE'
  1. ORDERBY SID DESC;
  1. 如果是RAC环境,那么最好使用下面SQL语句,使用全局视图GV$SESSION
  1. SELECT SID, SERIAL#, INST_ID, MODULE,STATUS
  1. FROM gv$session S
  1. WHERE S.USERNAME ISNOTNULL
  1. ANDUPPER(S.PROGRAM) IN ('TOAD.EXE', 'W3WP.EXE')
  1. AND S.LAST_CALL_ET >= 2 * 60*60
  1. AND S.STATUS = 'INACTIVE'
  1. ORDERBY INST_ID DESC
  1.  
  1.  
 
 
 CREATE OR REPLACE PROCEDURE SYS.DB_KILL_IDLE_CLIENTS AUTHID DEFINER AS
    job_no number;
    num_of_kills number := 0;
 BEGIN
 
    FOR REC IN
        (SELECT SID, SERIAL#, INST_ID, MODULE,STATUS
         FROM gv$session S
             WHERE S.USERNAME IS NOT NULL
             AND UPPER(S.PROGRAM) IN ('xxx', 'xxx.EXE')   
                  AND S.LAST_CALL_ET >= 2*60*60                              
             AND S.STATUS= 'INACTIVE'
         ORDER BY INST_ID ASC
             ) LOOP
          ---------------------------------------------------------------------------
          -- kill inactive sessions immediately
          ---------------------------------------------------------------------------
          DBMS_OUTPUT.PUT('LOCAL SID ' || rec.sid || '(' || rec.module || ')');
      execute immediate 'alter system kill session ''' || rec.sid || ', ' ||
                             rec.serial# || '''immediate' ;
 
          DBMS_OUTPUT.PUT_LINE('. killed locally ' || job_no);
          num_of_kills := num_of_kills + 1;
    END LOOP;
    DBMS_OUTPUT.PUT_LINE ('Number of killed xxxx system sessions: ' || num_of_kills);
 END DB_KILL_IDLE_CLIENTS;
 /
  1.  

然后,我们可以在作业(JOB)或Schedule里面定期调用该存储过程,也可以通过后台作业结合shell脚本实现定期清理空闲会话的功能。例如如下所示。

创建killSession.sh脚本,调用该存储过程SYS.DB_KILL_IDLE_CLIENTS

  1. 1:#!/bin/bash
  1. 2: 
  1. 3: 
  1. 4: 
  1. 5: logfile=/home/oracle/cron/session/log/killSession.log
  1. 6: 
  1. 7: echo " " >> $logfile 2>&1
  1. 8: echo "START ----`date`" >> $logfile 2>&1
  1. 9: sqlplus /nolog <<STATS
  1. 10: connect / as sysdba
  1. 11: exec sys.db_kill_idle_clients;
  1. 12: exit;
  1. 13: STATS
  1. 14: 
  1. 15: echo "END ------`date`" >> $logfile 2>&1

在crontab里面配置后台作业,每隔15分钟运行一次,清理哪些满足条件的空闲会话。

0,15,30,45 * * * * /home/oracle/cron/session/bin/killSession.sh >/dev/null 2>&1

Oracle清除数据库中长时间占用资源的非活动的会话的更多相关文章

  1. Oracle Time Model Statistics(时间模型统计)

    Oracle数据库从10g開始,启用以时间模型统计为主.命中率为辅等性能度量指标.基于时间模型统计,主要是基于操作类型測量在数据库中花费的时间的统计信息.最重要的时间模型统计是数据库时间.或DB时间. ...

  2. oracle 清空数据库缓存

    oracle 清除数据库缓存: alter system flush shared_pool ; alter system flush BUFFER_CACHE ;

  3. sql server 2000数据库 最近经常出现某进程一直占用资源,阻塞?死锁?

    OA的数据库最近多次出现某进程一直占用资源,导致其他进程无法执行.使用sp_who2 和 sql server profiler跟踪查询,发现有以下几个语句常常占用资源: 1.declare @P1 ...

  4. Oracle数据库更新时间的SQL语句

    ---Oracle数据库更新时间字段数据时的sql语句---格式化时间插入update t_user u set u.name='pipi',u.modifytime=to_date('2015-10 ...

  5. oracle查询最占用资源的查询

    从V$SQLAREA中查询最占用资源的查询 select b.username username,a.disk_reads reads,a.executions exec,a.disk_reads/d ...

  6. Oracle 11g数据库详解(2)

    FAILED_LOGIN_ATTEMPTS 用于指定连续登陆失败的最大次数 达到最大次数后,用户会被锁定,登陆时提示ORA-28000 UNLIMITED为不限制 精确无误差 是 实时 PASSWOR ...

  7. Oracle 11g数据库详解

    常见异常: ORA-14025:不能为实体化视图或实体化视图日志指定PARTITION ORA-14026:PARTITION和CLUSTER子句互相排斥 ORA-14027:仅可以指定一个PARTI ...

  8. 区分Oracle的数据库,实例,服务名,SID

    文章摘自:http://www.zhetao.com/content240 感谢分享O(∩_∩)O~ 在实际的开发应用中,关于Oracle数据库,经常听见有人说建立一个数据库,建立一个Instance ...

  9. 【Oracle】转:通过案例学调优之--Oracle Time Model(时间模型)

    转自:http://blog.51cto.com/tiany/1596012 通过案例学调优之--Oracle Time Model(时间模型) 数据库时间 优化不仅仅是缩短等待时间.优化旨在缩短最终 ...

随机推荐

  1. sqrt()平方根计算函数的实现2——牛顿迭代法

    牛顿迭代法: 牛顿迭代法又称为牛顿-拉夫逊方法,它是牛顿在17世纪提出的一种在实数域和复数域上近似求解方程的方法.多数方程不存在求根公式,因此求精确根非常困难,甚至不可能,从而寻找方程的近似根就显得特 ...

  2. 查看apache,mysql,nginx,php的编译参数

    查看nginx编译参数:/usr/local/nginx/sbin/nginx -V 查看apache编译参数:cat /usr/local/apache2/build/config.nice 查看m ...

  3. Web服务器磁盘满故障深入解析

    问题:硬盘显示被写满,但是用du -sh /*查看时占用硬盘空间之和还远小于硬盘大小即找不到硬盘分区是怎么被写满的. 今天下午接到一学生紧急求助,说生产线服务器硬盘满了.该删的日志都删掉了.可空间还是 ...

  4. jquery data属性的使用

    var func=function(){console.log("test")};$("div").data("test",func);$( ...

  5. laravel 框架memcache的配置

    Laravel5框架在Cache和Session中不支持Memcache,看清了是Memcache而不是Memcached哦,MemCached是支持的但是这个扩展真的是装的蛋疼,只有修改部分源码让其 ...

  6. Vijos1327回文词【动态规划】

    回文词 回文词是一种对称的字符串--也就是说,一个回文词,从左到右读和从右到左读得到的 结果是一样的.任意给定一个字符串,通过插入若干字符,都可以变成一个回文词.你的任务是写 一个程序,求出将给定字符 ...

  7. 老李推荐:第6章5节《MonkeyRunner源码剖析》Monkey原理分析-事件源-事件源概览-事件

    老李推荐:第6章5节<MonkeyRunner源码剖析>Monkey原理分析-事件源-事件源概览-事件   从网络过来的命令字串需要解析翻译出来,有些命令会在翻译好后直接执行然后返回,但有 ...

  8. 老李分享: Oracle Performance Tuning Overview 翻译下

    1.2性能调优特性和工具 Effective data collection and analysis isessential for identifying and correcting perfo ...

  9. 635B. Bear and Compressing

    B. Bear and Compressing time limit per test 2 seconds memory limit per test 256 megabytes input stan ...

  10. JavaWeb总结(七)—JSTL标签库

    一.JSTL标签库介绍 JSTL标签库的使用时为了弥补HTML标签的不足,规范自定义标签的使用而诞生的.使用JSTL标签的目的是不希望在JSP中出现Java逻辑代码. 二.JSTL标签库的分类 1.核 ...