1.1 现象描写叙述
数据库节点响应缓慢,部分用户业务受到影响。
查看数据库告警日志,開始显示 ORA-07445 错误,然后是大量的 ORA-04031 错误和 ORA-00600 错误。
检查数据库日志,数据库仍处于活动状态的信息例如以下:
Sat Jul 17 07:51:52 2010
Thread 1 advanced to log sequence 266272
Current log# 2 seq# 266272 mem# 0: /dev/rlv_redo121
Current log# 2 seq# 266272 mem# 1: /dev/rlv_redo122
1.2 可能原因
因为数据库用户业务繁忙,活动会话较多,占用了大量的Shared Pool内存。同一时候Shared Pool内部參数配置不合理导致产生大量的内存碎片。因此,导致部分进程无法申请到足够的Shared Pool内存,出现 ORA-07445 错误和 ORA-04031 错误。因为Shared Pool压力越来越大,最后还引发 ORA-00600 错误。
1.3 处理步骤
- 以 oracle 用户登录数据库主机。
- 以 sysdba 用户连接数据库。
% sqlplus /nolog
SQL> conn /as sysdba;
Connected.
- 提高 Shared Pool 的“ reserved pool ”比例。
SQL> alter system set "_shared_pool_reserved_pct"=10 scope=spfile;
- 减少“ reserved pool ”的最小请求大小。
SQL> alter system set "_shared_pool_reserved_min_alloc"=4000 scope=spfile;
- 将 Shared Pool 子池个数降低到两个。
SQL> alter system set "_kghdsidx_count"=2 scope=spfile;
- 分别关闭主备节点数据库。
SQL> shutdown immediate
- 分别在主备节点又一次启动数据库。
SQL> startup
- 查询设置的參数。
SQL> select a.ksppinm "Parameter", b.ksppstvl "Session Value", c.ksppstvl "Instance Value"
from x$ksppi a, x$ksppcv b, x$ksppsv c
where a.indx = b.indx and a.indx = c.indx and a.ksppinm = '_shared_pool_reserved_pct';