oracle许多inactive会话久久不释放,我该怎么办

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle许多inactive会话久久不释放,我该怎么办相关的知识,希望对你有一定的参考价值。

正常的,原因是有连接数据库,但是没有会话的操作,一般情况下不需要处理。
需要注意的是,如果会话太多,会到数据库会话限制,这个时候需要杀数据库会话和操作系统进程。
参考技术A 执行 alter system checkpoint ; 即可

oracle连接数过多 如何释放

释放连接只能是让一些连接的进程断开连接。
查询哪个user的连接数最多,先跟他们的用户说,不能连接这么多的进程,让他们释放一些,如果释放了,系统正常了,那么就限制每个用户连接数,不让他们连接这么多。
如果不释放,你就在操作系统层面把他们那些进程kill掉,有人来找就让他们对系统夯住负责,然后限制用户的连接数。
不过这么操作的风险还是不小的,自己掂量。
参考技术A Oracle服务器连接数过多会当掉,把连接数过多的客户机网线拔出后,在远程Oracle上依然还会保留此用户的连接数,久久不能释放,上网查了下可以以下面方法解决。
  通过profile可以对用户会话进行一定的限制,比如IDLE时间。
  将IDLE超过一定时间的会话断开,可以减少数据库端的会话数量,减少资源耗用。
  使用这些资源限制特性,需要设置resource_limit为TRUE:
  [oracle@test126 udump]$ sqlplus “/ as sysdba”
  SQL*Plus: Release 10.2.0.1.0 - Production on Fri Oct 13 07:58:21 2006
  Copyright (c) 1982, 2005, Oracle. All rights reserved.
  Connected to:
  Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
  With the Partitioning and Data Mining options
  SQL> show parameter resource
  NAME TYPE VALUE
  ———————————— ———– ——————————
  resource_limit boolean TRUE
  resource_manager_plan string
  该参数可以动态修改:
  SQL> alter system set resource_limit=true;
  System altered.
  数据库缺省的PROFILE设置为:
  SQL> SELECT * FROM DBA_PROFILES;
  PROFILE RESOURCE_NAME RESOURCE LIMIT
  ——————– ——————————– ——– —————
  DEFAULT COMPOSITE_LIMIT KERNEL UNLIMITED
  DEFAULT SESSIONS_PER_USER KERNEL UNLIMITED
  DEFAULT CPU_PER_SESSION KERNEL UNLIMITED
  DEFAULT CPU_PER_CALL KERNEL UNLIMITED
  DEFAULT LOGICAL_READS_PER_SESSION KERNEL UNLIMITED
  DEFAULT LOGICAL_READS_PER_CALL KERNEL UNLIMITED
  DEFAULT IDLE_TIME KERNEL UNLIMITED
  DEFAULT CONNECT_TIME KERNEL UNLIMITED
  DEFAULT PRIVATE_SGA KERNEL UNLIMITED
  DEFAULT FAILED_LOGIN_ATTEMPTS PASSWORD 10
  DEFAULT PASSWORD_LIFE_TIME PASSWORD UNLIMITED
  PROFILE RESOURCE_NAME RESOURCE LIMIT
  ——————– ——————————– ——– —————
  DEFAULT PASSWORD_REUSE_TIME PASSWORD UNLIMITED
  DEFAULT PASSWORD_REUSE_MAX PASSWORD UNLIMITED
  DEFAULT PASSWORD_VERIFY_FUNCTION PASSWORD NULL
  DEFAULT PASSWORD_LOCK_TIME PASSWORD UNLIMITED
  DEFAULT PASSWORD_GRACE_TIME PASSWORD UNLIMITED
  16 rows selected.
  创建一个允许3分钟IDLE时间的PROFILE:
  SQL> CREATE PROFILE KILLIDLE LIMIT IDLE_TIME 3;
  Profile created.
  新创建PROFILE的内容:
  SQL> col limit for a10
  SQL> select * from dba_profiles where profile=’KILLIDLE’;
  PROFILE RESOURCE_NAME RESOURCE LIMIT
  —————————— ——————————– ——– ———-
  KILLIDLE COMPOSITE_LIMIT KERNEL DEFAULT
  KILLIDLE SESSIONS_PER_USER KERNEL DEFAULT
  KILLIDLE CPU_PER_SESSION KERNEL DEFAULT
  KILLIDLE CPU_PER_CALL KERNEL DEFAULT
  KILLIDLE LOGICAL_READS_PER_SESSION KERNEL DEFAULT
  KILLIDLE LOGICAL_READS_PER_CALL KERNEL DEFAULT
  KILLIDLE IDLE_TIME KERNEL 3
  KILLIDLE CONNECT_TIME KERNEL DEFAULT
  KILLIDLE PRIVATE_SGA KERNEL DEFAULT
  KILLIDLE FAILED_LOGIN_ATTEMPTS PASSWORD DEFAULT
  KILLIDLE PASSWORD_LIFE_TIME PASSWORD DEFAULT
  PROFILE RESOURCE_NAME RESOURCE LIMIT
  —————————— ——————————– ——– ———-
  KILLIDLE PASSWORD_REUSE_TIME PASSWORD DEFAULT
  KILLIDLE PASSWORD_REUSE_MAX PASSWORD DEFAULT
  KILLIDLE PASSWORD_VERIFY_FUNCTION PASSWORD DEFAULT
  KILLIDLE PASSWORD_LOCK_TIME PASSWORD DEFAULT
  KILLIDLE PASSWORD_GRACE_TIME PASSWORD DEFAULT
  16 rows selected.
  测试用户:
  SQL> select username,profile from dba_users where username=’EYGLE’;
  USERNAME PROFILE
  —————————— ——————–
  EYGLE DEFAULT
  修改eygle用户的PROFILE使用新建的PROFILE:
  SQL> alter user eygle profile killidle;
  User altered.
  SQL> select username,profile from dba_users where username=’EYGLE’;
  USERNAME PROFILE
  —————————— ——————–
  EYGLE KILLIDLE
  进行连接测试:
  [oracle@test126 admin]$ sqlplus eygle/eygle@eygle
  SQL*Plus: Release 10.2.0.1.0 - Production on Fri Oct 13 08:07:13 2006
  Copyright (c) 1982, 2005, Oracle. All rights reserved.
  Connected to:
  Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
  With the Partitioning and Data Mining options
  SQL> select username,profile from dba_users where username=’EYGLE’;
  USERNAME PROFILE
  —————————— ——————————
  EYGLE KILLIDLE
  当IDLE超过限制时间时,连接会被断开:
  SQL> select to_char(sysdate,’yyyy-mm-dd hh24:mi:ss’) from dual;
  TO_CHAR(SYSDATE,’YY
  ——————-
  2006-10-13 08:08:41
  SQL> select to_char(sysdate,’yyyy-mm-dd hh24:mi:ss’) from dual;
  select to_char(sysdate,’yyyy-mm-dd hh24:mi:ss’) from dual
  *
  ERROR at line 1:
  ORA-02396: exceeded maximum idle time, please connect again

以上是关于oracle许多inactive会话久久不释放,我该怎么办的主要内容,如果未能解决你的问题,请参考以下文章

ORACLE定期清理INACTIVE会话

ORACLE定期清理INACTIVE会话

plsql会话inactive状态 程序还在执行吗

Oracle查询session连接数和inactive

oracle连接数过多 如何释放

Oracle inactive session的清理