Oracle 超时设置2:设置实例级参数

简介: Oracle超时设置系列的第二篇文章,设置实例级参数

     dba经常会被开发或应用运维人员问起,数据库的会话超时时间的是多少,应用的数据库会话在多长时间会被终结,或者说kill掉。MySQL dba在被问起这个问题时回答起来非常简单,一般就是两个超时参数。Oracle dba回答起来可能更简单,可能就一句话,会话没有超时设置。这个简单的回答其实掩盖了Oracle数据库会话超时设置的复杂性。Oracle会话的超时设置可以在net services中设置,也可以设置实例级参数,还可以在用户的profile中设置,本文时这个系列的第二篇,谈谈会话超时的实例级参数。

1 会话超时实例级参数

     Oracle数据库中,可以设置max_idle_time和max_idle_blocker_time两个实例级别的会话超时参数,从v$parameter视图中看一下这两个视图的说明。

SQL> l
1*select NAME,DESCRIPTION from v$parameter where name like'%idle%'NAME                     DESCRIPTION
------------------------ --------------------------------------------------------------------------------max_idle_time            maximum session idle timein minutes
max_idle_blocker_time    maximum idle time for a blocking session in minutes

      这两个参数的单位都是分钟,max_idle_time设置的会话空闲最大时间,会话空闲超过这个时间会被终结,对应的Oracle服务进程会被kill掉。max_idle_blocker_time设置的时阻塞会话的最大空闲时间,阻塞会话空闲时间超过设定值会被kill掉。这两个参数有没有默认值,可不可以在会话级设置,设置后是不是要重启一下服务器,这些信息也可以从v$parameter视图中查询到。

SQL>select NAME,VALUE,ISDEFAULT,ISSYS_MODIFIABLE,ISSES_MODIFIABLE from v$parameter where name like'%idle%';NAME                     VALUE                ISDEFAULT ISSYS_MOD ISSES
------------------------ -------------------- --------- --------- -----max_idle_time            0TRUE      IMMEDIATE FALSEmax_idle_blocker_time    0TRUE      IMMEDIATE FALSE

      可以看到这两个参数的默认值都是0,也就是没有超时设置,这两个参数都是实例级可调的,调整后立即生效。在会话级,这两个参数都不能调整。可以验证一下

SQL>alter session set max_idle_time=0;alter session set max_idle_time=0*ERROR at line 1:ORA-02096: specified initialization parameter isnot modifiable with this
option

     可以看到,这个参数在alter session时不能调整。

     max_idle_blocker_time时阻塞会话的超时限制,什么时阻塞会话,Oracle官方文档对此有个说明:

A session is considered to be a blocking session when it is holding resources required
by other sessions. For example:• The session is holding a lock required by another session.
• The session is a parallel operation and its consumer group, PDB,or database has
either reached its maximum parallel server limitor has queued parallel operations.
• The session’s PDB or database instance is about to reach its SESSIONS orPROCESSES limit.

     简单翻译下就是:一个会话当它持有其它会话需要的资源时被认为是阻塞会话。例如:

         会话持有其它会话需要的锁。

         会话执行一个并行操作,它的消费者组,PDB或者数据库达到了最大并行服务器限制或者排队的并行操作。

          会话的PDB或者是数据库实例即将达到会话和进程限制。

      官网列举的三个例子中,持有锁的阻塞会话比较常见,其它两种情况也需要注意。

2 实验验证max_idle_time参数

     下面通过一个小实验验证一下这个参数,数据库的版本是

SQL>select BANNER_FULL from v$version;BANNER_FULL
--------------------------------------------------------------------------------Oracle Database 19c Enterprise Edition Release 19.0.0.0.0- Production
Version 19.3.0.0.0

       max_idle_time的默认参数为0,将它改为1分钟,

SQL>alter system set max_idle_time=1;System altered.
SQL> show parameter max_idle_time
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------max_idle_time                        integer1

打开一个会话,先运行一条sql,在等待1分钟后,在运行sql

SQL>select sysdate from dual;SYSDATE
-------------------2023-02-1600:50:29SQL>select*from t_test;select*from t_test
*ERROR at line 1:ORA-03135: connection lost contact
Process ID:12154Session ID:70 Serial number:30076

执行sql报错,连接丢失,会话被kill的信息可以在数据库的alert.log中看到

2023-02-16T00:58:06.077747-05:00KILL SESSION for sid=(70,30076):  Reason = max_idle_time parameter
  Mode = KILL HARD SAFE -/-/NO_REPLAY
  Requestor = PMON (orapid =2, ospid =1723, inst =1)  Owner = Process: USER (orapid =49, ospid =12154)  Result = ORA-0

      这里被kill掉的会话的sid和serial#和之前报错的会话相同。alert日志里还可以看到会话被kill掉的原因Reason = max_idle_time parameter。

      这个实验反复试过几次,更改过参数后,对之前的会话也是生效的,对sys用户不生效,和登录方式没有关系。

     实验完成后,重置这个参数

SQL>alter system reset max_idle_time;System altered.
SQL> show parameter max_idle_time
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------max_idle_time                        integer1

       reset操作在不设置范围时只更改spfile里的值,要重置内存里的参数,需要指定范围

SQL>alter system reset max_idle_time scope=memory;System altered.
SQL> show parameter max_idle_time
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------max_idle_time                        integer0

3 验证max_idle_blocker_time参数

   使用行锁验证这个参数,首先,设置这个参数为1分钟

SQL>alter system set max_idle_blocker_time=1;System altered.
SQL> show parameter max_idle_blocker_time
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------max_idle_blocker_time                integer1

创建两个会话,关闭自动提交,运行更新语句更新一个有主键表同一主键值

会话1先运行更新语句

SQL>set autoc off
SQL> show autoc
autocommit OFF
SQL>update t_test set id=12where id=2;1 row updated.
SQL>select*from t_test;select*from t_test
*ERROR at line 1:ORA-03113: end-of-file on communication channel
Process ID:17950Session ID:36 Serial number:25168

然后再会话2上运行更新语句

SQL>set autoc 0SQL> show autoc
autocommit OFF
SQL>update t_test set id=102where id=2;1 row updated.

      会话2在运行这个语句的时候被会话1阻塞,产生了行锁等待,会话1空闲时间超过1分钟之后,被数据库kill掉,会话2的更新操作成功。数据库告警日志里也有这次操作的信息

2023-02-16T02:48:18.203413-05:00Process termination requested for pid 17950[source = rdbms],[info =2][request issued by pid:1723, uid:54321]2023-02-16T02:48:18.252757-05:00KILL SESSION for sid=(36,25168):  Reason = max_idle_blocker_time parameter
  Mode = KILL HARD SAFE -/-/NO_REPLAY
  Requestor = PMON (orapid =2, ospid =1723, inst =1)  Owner = Process: USER (orapid =51, ospid =17950)  Result = ORA-0

      可以看到会话被kill掉的原因Reason = max_idle_blocker_time parameter,会话的sid和serial#,和会话1相同。

  4 小结

     在实例级别设置会话超时参数对数据库系统的sys用户不生效,对自定义的用户有效,会话因空闲超时被kill数据库的告警日志里会有记录。特别是max_idle_blocker_time这个参数,对于防止长时间的行锁有一定的作用,比如有些应用获得行锁后去做别的事情,导致其它会话长时间等待,这种场合下应该适用这个参数。



相关文章
|
7天前
|
监控 Oracle 关系型数据库
Linux平台Oracle开机自启动设置
【11月更文挑战第8天】在 Linux 平台设置 Oracle 开机自启动有多种方法,本文以 CentOS 为例,介绍了两种常见方法:使用 `rc.local` 文件(较简单但不推荐用于生产环境)和使用 `systemd` 服务(推荐)。具体步骤包括编写启动脚本、赋予执行权限、配置 `rc.local` 或创建 `systemd` 服务单元文件,并设置开机自启动。通过 `systemd` 方式可以更好地与系统启动过程集成,更规范和可靠。
|
6月前
|
负载均衡 Oracle 关系型数据库
Linux启动多个Oracle实例
Linux启动多个Oracle实例
103 0
|
8天前
|
Oracle 关系型数据库 数据库
【赵渝强老师】Oracle的参数文件与告警日志文件
本文介绍了Oracle数据库的参数文件和告警日志文件。参数文件分为初始化参数文件(PFile)和服务器端参数文件(SPFile),在数据库启动时读取并分配资源。告警日志文件记录了数据库的重要活动、错误和警告信息,帮助诊断问题。文中还提供了相关视频讲解和示例代码。
|
8天前
|
Oracle Ubuntu 关系型数据库
Linux平台Oracle开机自启动设置
【11月更文挑战第7天】本文介绍了 Linux 系统中服务管理机制,并详细说明了如何在使用 systemd 和 System V 的系统上设置 Oracle 数据库的开机自启动。包括创建服务单元文件、编辑启动脚本、设置开机自启动和启动服务的具体步骤。最后建议重启系统验证设置是否成功。
|
4月前
|
SQL Oracle 关系型数据库
关系型数据库Oracle设置 RMAN 环境:
【7月更文挑战第25天】
69 2
|
4月前
|
Oracle 关系型数据库 Unix
关系型数据库Oracle设置环境变量:
【7月更文挑战第22天】
544 4
|
6月前
|
Oracle 关系型数据库 Java
Oracle 19c 查看隐含参数视图
Oracle 19c 查看隐含参数视图
101 7
|
6月前
|
SQL 监控 Oracle
Oracle 性能优化之AWR、ASH和ADDM(含报告生成和参数解读)
Oracle 性能优化之AWR、ASH和ADDM(含报告生成和参数解读)
|
6月前
|
运维 Oracle 关系型数据库
Oracle服务器参数文件:数据王国的“调控大师”
【4月更文挑战第19天】Oracle服务器参数文件,数据库的“调控大师”,掌控着内存管理、进程调度等关键设置。通过参数调整如SGA_MAX_SIZE和PROCESSES,实现性能优化和故障防控。虽然挑战重重,但成功的性能调优带来无尽成就感。它在备份恢复中也扮演重要角色,保障数据一致性与可用性。成为真正的“调控大师”,为数据王国效力!
|
6月前
|
存储 SQL Oracle
【Oracle】玩转Oracle数据库(二):体系结构、存储结构与各类参数
【Oracle】玩转Oracle数据库(二):体系结构、存储结构与各类参数
111 7