一 、前言:从技术管理的角度上来说,软件应该越来越倾向于自动化管理,其实ORACLE也一直在往这方面做准备,内存的管理就是一个很好的例子;从Oracle从9i开始逐渐开始实现内存的只能花管理,10G引进了SGA的自动化管理,11G开始SGA和PGA进行了统一的管理的,实现内存的完全自动化管理(Automatic Memory Management,AMM) ,极大的简化了DBA的工作;
二 、参数介绍:11G开始内存的自动管理引进了两个参数:MEMORY_TARGET:操作系统的角度上 Oracle 所能使用的最大内存值。动态参数
MEMORY_MAX_TARGET:MEMORY_TARGET所能设定的最大值。非动态可调。
AMM 在后台会启动一个内存管理(Memory Manager, mman)进程。
三 、内存管理的方式介绍:
由于AMM的引进,内存的管理就有很多的选择,如下
- 自动内存管理
- 自动共享内存管理
- 手工共享内存管理
- 自动PGA管理
- 手动PGA管理
1、 自动内存管理
默认安装的实例即是 AMM 方式。如下
SQL> show parameters target
如图显示:sga_target和pga_aggregate_target都为0
2.自动共享内存管理(Automatic Shared Memory Management, ASMM)这是 10g 引入的管理方式,要使用这种方式,需要设置初始化参数 MEMORY_TARGET=0 ,然后显式的指定 SGA_TARGET 的值。SQL> alter system set sga_target=2048m scope=both;
alter system set sga_target=1024m scope=both*ERROR at line 1:ORA-02097: parameter cannot be modified because specified value is invalidORA-00839: SGA_TARGET cannot be modified to the specified valueSQL> alter system set memory_target=0 scope=both;System altered.SQL> alter system set sga_target=1024m scope=both;System altered.SQL>
这两个参数的修改是有严格顺序的,如果不遵守倒也没问题–Oracle 会报告错误。
3.手工共享内存管理
这个又更加原始了一些。因为原始,所以新的初始化参数 SGA_TARGET 与 MEMORY_TARGET 都要设置为 0. 然后手工设定 share_pool_size 、db_cache_size 等 sga 参数。要注意 RESULT_CACHE_SIZE 参数是 11g 新引入的,用来缓存 SQL 结果。
4.自动 PGA 内存管理
如果使用 AMM , 则对 PGA 不用操心。如果要做到精细控制而切换到自动 PGA 内存管理模式,需要设定WORKAREA_SIZE_POLICY = AUTO(默认即为 AUTO),然后需要指定 PGA_AGGREGATE_TARGET 的值。如需要精确控制PGA,则 WORKAREA_SIZE_POLICY = MANUAL .(Thanks vongates)
5.手动 PGA 管理
前提是 WORKAREA_SIZE_POLICY = manual ,然后分别指定 SORT_AREA_SIZE 等 PGA 相关的参数。估计现在没有人干这个吃力不讨好的事情了。这个模式大可以忽略。
AMM 的限制
如果初始化参数 LOCK_SGA = true ,则 AMM 是不可用的。
相关动态视图
V$MEMORY_DYNAMIC_COMPONENTSV$MEMORY_RESIZE_OPS
11g 在简化 DBA 基本工作上还是下了很大功夫。可是这样也掩盖了一些技术细节,Oracle 正在逐步把内存的管理变成一个黑盒子,当然这也也是相关算法更加稳定作为基础的。(因为这个原因SAP的数据的内存管理采用的是笨拙但稳定的手工内存管理),但是在一些小的系统可以采用自动内存管理。
备注: 如果使用的是 pfile,设定了 MEMORY_TARGET 而没有指定 MEMORY_MAX_TARGET 的值,则实例启动后 MEMORY_MAX_TARGET 的值与 MEMORY_TARGET 相等。如果 pfile 中指定了 MEMORY_MAX_TARGET 而没有指定 MEMORY_TARGET ,实例启动后 MEMORY_TARGET 为 0 。
以上的内容主要摘自网友,在内存管理的第二篇中,将更多的介绍实际的操作,敬请各位的关注!
......................................................................................................................................................................................................................本文作者:JOHN
ORACLE技术博客:ORACLE 猎人笔记 数据库技术群:367875324 (请备注ORACLE管理 )
......................................................................................................................................................................................................................