设为首页 加入收藏

TOP

Oracle数据库案例整理-Oracle系统运行时故障-SharedPool内存不足导致数据库响应缓慢
2014-11-23 21:48:54 来源: 作者: 【 】 浏览:12
Tags:Oracle 数据库 案例 整理 -Oracle 系统 行时 故障 -SharedPool 内存 不足 导致 响应 缓慢

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

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Oracle学习笔记13--控制用户权限 下一篇Oracle数据库案例整理-Oracle系统..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: