客户想实现对会话空闲时间的控制,下面是做的一个例子。

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--

查看oracle会话空闲时间,使用Oracle PROFILE控制会话空闲时间相关推荐

  1. oracle最大空闲时间,使用Oracle PROFILE控制会话空闲时间

    Oracle推荐PROFILE和SQLNET.EXPIRE_TIME一起使用,但由于PL/SQL工具本身的特点,它会在SESSION的状态变成SNIPED(PROFILE IDLE_TI 客户想实现对 ...

  2. MySQL空闲会话_使用Oracle PROFILE控制会话空闲时间

    Oracle推荐PROFILE和SQLNET.EXPIRE_TIME一起使用,但由于PL/SQL工具本身的特点,它会在SESSION的状态变成SNIPED(PROFILE IDLE_TI 客户想实现对 ...

  3. 定时关机软件里的锁定计算机,易通电脑锁(控制限制上网时间的软件)

    控制管理上网时间和电脑使用时间必备软件,可按时间分段和累计时间控制管理.定时多任务(关机/锁机/重启/打开或关闭程序/删除文件/备份文件等).记录电脑开关机时间和使用时间.记录文件操作日志(新建/复制 ...

  4. oracle time model,通过案例学调优之--OracleTimeModel(时间模型)

    通过案例学调优之--Oracle Time Model(时间模型) 650) this.width=650;" src="http://www.68idc.cn/help/uplo ...

  5. oracle执行计划time单位,Oracle中查看执行计划

    方法一.通过使用工具PLSQL Developer中的Explain Plan Window窗口查看SQL执行计划.具体参考 方法二.通过SQL*PLUS中的autotrace命令查看 1.登录拥有d ...

  6. oracle用dual创建临时表,Oracle 学习系列之二(会话与事务级临时表和dual表 )

    一. 会话临时表 --创建会话临时表 create global temporary table tmp_user_session(user_id int, user_name varchar2(20 ...

  7. oracle数据库报300006,Oracle归档日志所在目录时间不对Oracle集群日志时间显示错误...

    Oracle归档日志所在目录时间不对&&Oracle集群日志时间显示错误 Oracle归档日志所在目录时间不对&&Oracle集群日志时间显示错误 前言 这个问题在18 ...

  8. oracle如何查询时间格式,oracle时间格式讨论

    1. oracle对时间格式的数据存贮 Oracle以特定的存储格式来存储时间,占7个字节,与查询显示的时间无关.存贮的时间包括年月日时分秒,最小精度为秒,不存贮秒以下的时间单位.因此在一些前台支持毫 ...

  9. oracle查看有哪些数据库用户登录,oracle如何查看当前有哪些用户连接到数据库,oracle当前有...

    oracle如何查看当前有哪些用户连接到数据库,oracle当前有 可以执行以下语句: select username,serial#, sid from v$session; ---查询用户会话 a ...

最新文章

  1. 10年开发经验大佬分享一个数据库系统知识图谱
  2. DFA确定性有穷自动机及其化简
  3. 使用javadoc命令生成文档
  4. python遇到错误跳过_python except异常处理之后不退出,解决异常继续执行的实现
  5. pythonjson中list操作_python3中json与JsonPath用法详解
  6. php中unset函数是在哪一章_php函数可以分为哪三种
  7. 一朝读码深似海,不读源码薪难升!读懂.NET5源码,到底多重要?
  8. java pojo使用_在POJO中使用ThreadLocal进行Java嵌套事务
  9. Eclipse 插件ibeetl
  10. java connection 单例_Java设计模式之单例模式详解
  11. 优秀的程序员真的不写注释吗? | 原力计划
  12. predicate 列存储索引扫描_MySQL中IS NULL、IS NOT NULL、!=不能用索引?胡扯!
  13. find 命令详解 基于文件大小,名字和权限等的查找策略以及-path和-prune的详细解释
  14. 如何下载vue.js
  15. php mysql手册下载chm_PHP7教程|PHP7中文手册下载chm版 - 欧普软件下载
  16. tensorflow系列之_pspnet网络
  17. python的一个基础性问题,求平行四边形的面积
  18. 【JZOJ B组】【NOI2002】贪吃的九头龙
  19. css实现六边形图片(最简单易懂方法实现高逼格图片展示)
  20. 【渝粤教育】电大中专跨境电子商务理论与实务 (17)作业 题库

热门文章

  1. 关闭裁剪功能_SOLIDWORKS 2021 新增功能—3D CAD
  2. python两个csv表数据合并_怎么用python把一个*。csv 文件里面的数据整合成一个表格...
  3. df python 增加数据_美国确诊超100万!教你用Python画出全球疫情动态图(附数据下载)...
  4. android 隐藏输入法时自动关闭弹窗,Android监听输入法弹窗和关闭的实现方法
  5. 在Unity编辑器中开发遇到问题BUG如何调试解决?
  6. 【专栏精选】Unity中的HTTP网络通信
  7. UGUI字体不清楚——终极探索
  8. VS2010中使Unity3d的shader文件关键字高亮
  9. 连接Python 3和Electron/Node.JS:构建现代桌面应用程序
  10. ASP.NET核心之路微服务第02部分:查看组件