ORACLE 11G的内存管理 第一篇

简介: 一 、前言:从技术管理的角度上来说,软件应该越来越倾向于自动化管理,其实ORACLE也一直在往这方面做准备,内存的管理就是一个很好的例子;从Oracle从9i开始逐渐开始实现内存的只能花管理,10G引进了SGA的自动化管理,11G开始SGA和PGA进行了统一的管理的,实现内存的完全自动化管理(Automatic Memory Management,AMM) ,极大的简化了DBA的工作;  二 、参数介绍:11G开始内存的自动管理引进了两个参数:MEMORY_TARGET:操作系统的角度上 Oracle 所能使用的最大内存值。

一 、前言:从技术管理的角度上来说,软件应该越来越倾向于自动化管理,其实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管理 )  

......................................................................................................................................................................................................................

相关文章
|
Oracle 关系型数据库 数据库
Oracle 11G常见性能诊断报告(AWR/ADDM/ASH)收集
Oracle 11G常见性能诊断报告(AWR/ADDM/ASH)收集
507 0
|
Oracle 关系型数据库 数据库
使用docker安装配置oracle 11g
使用docker安装配置oracle 11g
|
Oracle 关系型数据库
分布式锁设计问题之Oracle RAC保证多个节点写入内存Page的一致性如何解决
分布式锁设计问题之Oracle RAC保证多个节点写入内存Page的一致性如何解决
186 0
|
Oracle 关系型数据库 数据库
Oracle 11G数据库安装步骤及截图操作2
Oracle 11G数据库安装步骤及截图操作
139 0
|
Oracle 安全 关系型数据库
Oracle 11G数据库安装步骤及截图操作1
Oracle 11G数据库安装步骤及截图操作
193 0
|
存储 NoSQL Oracle
Oracle 12c的内存列存储:数据的“闪电侠”
【4月更文挑战第19天】Oracle 12c的内存列存储以超高速度革新数据处理,结合列存储与内存技术,实现快速查询与压缩。它支持向量化查询和并行处理,提升效率,但需合理配置以平衡系统资源。作为数据管理员,应善用此功能,适应业务需求和技术发展。
|
存储 Oracle 关系型数据库
手把手教你安装Oracle——以oracle 11g为例
手把手教你安装Oracle——以oracle 11g为例
手把手教你安装Oracle——以oracle 11g为例
|
SQL Oracle 关系型数据库
docker 方式安装ORACLE 11g
docker 方式安装ORACLE 11g
1027 5
|
Oracle 关系型数据库 数据库
在Flink CDC中,使用Oracle 11g数据库的NUMBER类型作为主键
在Flink CDC中,使用Oracle 11g数据库的NUMBER类型作为主键
254 1
|
Oracle 关系型数据库
Oracle 11g和12c的主要区别
Oracle 11g和12c的主要区别

热门文章

最新文章

推荐镜像

更多