客户想实现对会话空闲时间的控制,下面是做的一个例子。
Microsoft Windows [版本 6.1.7601] 
版权所有 (c) 2009 Microsoft Corporation。保留所有权利。 
 
C:\Users\LIUBINGLIN>sqlplus sys/Oracle123@localhost:1521/hello as sysdba 
 
SQL*Plus: Release 11.2.0.3.0 Production on 星期二 4月 14 08:42:55 2015 
 
Copyright (c) 1982, 2011, Oracle.  All rights reserved. 
 
连接到: 
Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - Production 
With the Partitioning, OLAP, Data Mining and Real Application Testing options 
 
SQL> create profile test_profile limit idle_time 1;  表示允许的空闲时间为1分钟。 
 
配置文件已创建 
 
SQL> set linesize 200 
SQL> select * from dba_profiles where profile='TEST_PROFILE'; 
 
PROFILE                        RESOURCE_NAME                    RESOURCE LIMIT 
------------------------------ -------------------------------- -------- ---------------------------------------- 
TEST_PROFILE                  COMPOSITE_LIMIT                  KERNEL  DEFAULT 
TEST_PROFILE                  SESSIONS_PER_USER                KERNEL  DEFAULT 
TEST_PROFILE                  CPU_PER_SESSION                  KERNEL  DEFAULT 
TEST_PROFILE                  CPU_PER_CALL                    KERNEL  DEFAULT 
TEST_PROFILE                  LOGICAL_READS_PER_SESSION        KERNEL  DEFAULT 
TEST_PROFILE                  LOGICAL_READS_PER_CALL          KERNEL  DEFAULT 
TEST_PROFILE                  IDLE_TIME                        KERNEL  1 
TEST_PROFILE                  CONNECT_TIME                    KERNEL  DEFAULT 
TEST_PROFILE                  PRIVATE_SGA                      KERNEL  DEFAULT 
TEST_PROFILE                  FAILED_LOGIN_ATTEMPTS            PASSWORD DEFAULT 
TEST_PROFILE                  PASSWORD_LIFE_TIME              PASSWORD DEFAULT 
 
PROFILE                        RESOURCE_NAME                    RESOURCE LIMIT 
------------------------------ -------------------------------- -------- ---------------------------------------- 
TEST_PROFILE                  PASSWORD_REUSE_TIME              PASSWORD DEFAULT 
TEST_PROFILE                  PASSWORD_REUSE_MAX              PASSWORD DEFAULT 
TEST_PROFILE                  PASSWORD_VERIFY_FUNCTION        PASSWORD DEFAULT 
TEST_PROFILE                  PASSWORD_LOCK_TIME              PASSWORD DEFAULT 
TEST_PROFILE                  PASSWORD_GRACE_TIME              PASSWORD DEFAULT 
 
已选择16行。 
 
SQL> show parameter resource 
 
NAME                                TYPE        VALUE 
------------------------------------ ----------- ------------------------------ 
resource_limit                      boolean    FALSE 
resource_manager_cpu_allocation      integer    4 
resource_manager_plan                string 
 
SQL> alter system set resource_limit =true;    对PROFILE中KERNEL类型的项目进行控制需要将该参数设置为TRUE,PASSWORD类型的项目不受此参数限制。 
 
系统已更改。 
 
SQL> create user test111 identified by test111 default tablespace users temporary tablespace temp profile test_profile; 
 
用户已创建。 
 
SQL> grant connect,resource to test111; 
 
授权成功。 
 
另外窗口开一个会话: 
C:\Users\LIUBINGLIN>sqlplus test111/test111@localhost:1521/hello 
 
SQL*Plus: Release 11.2.0.3.0 Production on 星期二 4月 14 08:55:49 2015 
 
Copyright (c) 1982, 2011, Oracle.  All rights reserved. 
 
 
连接到: 
Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - Production 
With the Partitioning, OLAP, Data Mining and Real Application Testing options 
 
SQL> create table test (id number); 
create table test (id number) 

第 1 行出现错误: 
ORA-02396: 超出最大空闲时间, 请重新连接 
 
空闲一分钟后再操作就会收到上面的报错。

但是客户说以上的方法只是适用于SQLPLUS,对PL/SQL工具无效,下面讨论一下为什么对PL/SQL无效。

使用test111登陆PL/SQL之后查看数据库会话信息:

成功登陆后在数据库里面看到创建了两个session,可以看到session的login时间是11:17:09和11:17:28两个时间点。由于没有执行任何SQL,登陆成功后的session状态是INACTIVE的。

IDLE_TIME设置的为1分钟,1分钟后两个会话的状态变成了SNIPED,表示会话已经过期。

当在PL/SQL中执行任何SQL语句的时候,PL/SQL没有报错,成功执行。

但是从后台看,登陆时间变成了11:20:47和11:20:51,状态又变成了INACTIVE。

说明在PL/SQL执行SQL语句的时候自动的重新登陆了。

下面是SQLPLUS的情况:

11:37:26登陆成功后,为SQLPLUS创建了一个SESSION,

1分钟没操作后会话变成了SNIPED状态。

再次到该会话操作时,收到如下报错:

从上一张图片可以看出,从后台看SQLPLUS的SESSION已经被KILL。

由此可以判断,PROFILE IDLE_TIME对SQLPLUS有效,对PL/SQL无效跟客户端有很大关系。

通过这个实验还可以发现一点,会话过期后,会话的状态会变成SNIPED,该会话不会被立即KILL,直到会话对应的客户端下次执行SQL时被KILL,说明这段时间会话对应的服务器进程一直存在,如果这样的会话很多,且SNIPED存在的状态持续较长时间,那么数据库可能超过PROCESSES初始化参数的限制。

另外这里解释一下sqlnet.ora配置文件中配置SQLNET.EXPIRE_TIME参数的含义:

SQLNET.EXPIRE_TIME=1表示每过1分钟都向客户端发出一个测试连接的包,客户端收到后会给出响应,如果连接正常,这个连接是不会被杀掉的。

这个参数是用于解决客户端无故关闭,网络出现故障,再指定的时间内杀掉服务器进程。

Oracle推荐PROFILE和SQLNET.EXPIRE_TIME一起使用,但由于PL/SQL工具本身的特点,它会在SESSION的状态变成SNIPED(PROFILE IDLE_TIME超时)后,第一次操作的时候自动重新连接,所以这两种方法都控制不了它。

Oracle提出一种方法,就是在Oracle服务器端部署定时杀掉SNIPED状态会话的脚本。但是为了处理少量的PL/SQL客户端,未免有点大费周章了。

--end--

转:http://www.linuxidc.com/Linux/2015-05/117055.htm

使用Oracle PROFILE控制会话空闲时间的更多相关文章

  1. oracle限制一个用户空闲时间

    alter system set resource_limit = true; create profile idletime limit idle_time 3; alter user outln ...

  2. ORACLE:profile的管理

    PROFILE的管理(资源文件)      当需要设置资源限制时,必须设置数据库系统启动参数RESOURCE_LIMIT,此参数默认值为FALSE      可以使用如下命令来启动当前资源限制:    ...

  3. Oracle Profile使用详解(转)

    一.目的: Oracle系统中的profile可以用来对用户所能使用的数据库资源进行限制,使用Create Profile命令创建一个Profile,用它来实现对数据库资源的限制使用,如果把该prof ...

  4. Oracle profile含义、修改、新增

    profiles文件是口令和资源限制的配置集合,包括CPU的时间.I/O的使用.空闲时间.连接时间.并发会话数量.密码策略等对于资源的使用profile可以做到控制会话级别或语句调用级别.oracle ...

  5. ORACLE profile含义,修改,新增

    profiles文件是口令和资源限制的配置集合,包括CPU的时间.I/O的使用.空闲时间.连接时间.并发会话数量.密码策略等对于资源的使用profile可以做到控制会话级别或语句调用级别.oracle ...

  6. ORACLE定期清理INACTIVE会话

      ORACLE数据库会话有ACTIVE.INACTIVE.KILLED. CACHED.SNIPED五种状态.INACTIVE状态的会话表示此会话处于非活动.空闲.等待状态.例如PL/SQL Dev ...

  7. 【转】ORACLE定期清理INACTIVE会话

    源地址:http://www.cnblogs.com/kerrycode/p/3636992.html ORACLE数据库会话有ACTIVE.INACTIVE.KILLED. CACHED.SNIPE ...

  8. Oracle Profile 配置文件

    Profile是用户的配置文件,它是密码限制,资源限制的命名集合.利用profile 可以对数据库用户进行基本的资源管理,密码管理. 1 创建profile 的语法 create profile pr ...

  9. oracle查询和设置过期时间

    第一步:找到oracle 打开enterprise Manager Console如下图: 第二步,找到概要文件: sys 用户进入,找到你的数据库(如:ora8)-“安全性”-"用户&qu ...

随机推荐

  1. python-day45--mysql索引

    一 .介绍 为何要有索引? 一些复杂的查询操作,对查询语句的优化显然是重中之重.说起加速查询,就不得不提到索引了. 什么是索引? 索引在MySQL中也叫做“键”,是存储引擎用于快速找到记录的一种数据结 ...

  2. python中的注意事项

    .python 中的 and 从左到右计算表达式,若所有值均为真,则返回最后一个值,若存在假,返回第一个假值: or 也是从左到有计算表达式,返回第一个为真的值: 其中数字 0 是假,其他都是真: 字 ...

  3. SecureCRT 7.2.0 Mac版密码无法保存的解决办法

    参考:http://jingyan.baidu.com/article/915fc414fda5fb51394b20bd.html 我之前在网上找的解决办法都是SecureCRT 7.2.0 Mac ...

  4. python 使用yield进行数据的流式处理

    demo:从文件中取包含字符“a”的5行数据做一次批处理!!! # coding: utf-8 import time def cat(f): for line in f: yield line de ...

  5. PHP:第三章——PHP中函数的实参多余形参的处理方法

    <?phpheader("Content-Type:text/html;charset=utf-8");//传参的函数/*function F($a){    echo $a ...

  6. 若所有的参数皆需要类型转换——请为此采用non-member函数

    若所有的参数皆需要类型转换--请为此采用non-member函数 经常使用C++的程序猿(希望更多的程序媛),一般不会同意让classes支持类型转换,至于为什么,请看后续的博客.假如我们设计一个表示 ...

  7. hdu 3072 Intelligence System(Tarjan 求连通块间最小值)

    Intelligence System Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) ...

  8. c++模板函数声明定义分离编译错误详解

    今天看到accelerated c++上有个简单的vector容器的实现Vec,就再vs2008上编译了下: ///// Vec.h #ifndef GUARD_VEC_H #define GUARD ...

  9. 打开TestFlight并链接到具体的应用下载界面

    在我们应用正式上线前,许多时候都会有小流量的测试,选取部分核心用户抢先试用,在TestFlight出来之前,一般都是通过企业证书打包,然后提供给用户下载地址,安装测试使用,这个有个不爽之处就是,企业i ...

  10. ansible role[初稿]

    ansible roles role_name/ files/:存储由copy或script等模块调用的文件: tasks/:此目录中至少应该有一个名为main.yml的文件,用于定义各task:其它 ...