自动内存管理类型
- 自动内存管理:Oracle 11g的新特性,允许数据库完全自动地管理内存的SGA和PGA组件
- 自动共享内存管理:应用此选择,可以自动管理SGA,但是不自动管理PGA。
- 自动PGA内存管理:此选项只能自动管理SGA。
- 手动共享内存管理:手动设置SGA的组件尺寸,如:shared_pool,data_buffer
- 手动PGA管理:手动设置PGA组件尺寸
开启自动内存管理为开启自动内存管理,必须设置memory_target参数,该参数设置实例的目标内存。也可以指定memory_max_target初始化参数设置一个实例的最大内存尺寸。在用新的自动内存管理特性给数据库分配适当的尺寸之前,必须首先查找当前有多少内存分配给了SGA和PGA。但是并不意味简单的将sga_target和pga_target参数求和相加的内存需求。原因是:与sga_target参数不同,数据库不立即接管分配给pga_target参数的内存。数据库只根据pga_target参数设置将PGA分配给每个部分,因此,你的pga_target也许分配得很大,但是数据库在给定时间内却只是用了很小的一部分。
推荐阅读:Oracle 内存自动管理http://www.linuxidc.com/Linux/2013-03/80402.htmOracle安装过程物理内存检查及临时temp空间不足解决办法 http://www.linuxidc.com/Linux/2013-07/86829.htm因此需要做如下操作,来确定自动内存管理的内存大小1、查找当前SGA大小 SQL> show parameter sga
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
sga_target big integer 600M 2、查找给定时间内分配给PGA的大小SQL> select value from v$pgastat where name="maximum PGA allocated";
VALUE
----------
2487070723、2步得到的查询结果显示PGA分配的最大内存大约为236M,执行一下操作 得到一个错误的PGA估计
SQL> show parameter pga_
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
pga_aggregate_target big integer 400000000
4、通过将SGA_TARGET参数值和实例启动以来分配给PGA最大的内存值相加,选择memory_target参数值。(600+236)。如果需要,也可以设置memory_max_target,如果不给定该参数值,将使用memory_target的值。设置:alter system set memory_target=1200M scope=spfile;alter system set memory_max_target=1000M scope=spfile;alter system set sga_target=1200M scope=spfile;alter system set pga_aggregate_target=1200M scope=spfile; oracle内存管理方法的总结:
继续阅读:http://www.linuxidc.com/Linux/2013-07/88121p2.htm
rman catalog (rman 恢复目录)undo 表空间损坏导致无法open相关资讯 Oracle内存 Oracle内存管理
- 关于Oracle的内存问题 (02/08/2015 20:35:42)
- Oracle 内存自动管理 (03/05/2013 09:38:57)
| - Oracle内存结构 (06/30/2013 09:39:27)
- Oracle 内存分配小记 (10/07/2012 19:04:19)
|
本文评论 查看全部评论 (0)