AMM和ASMM理解

AMM和ASMM理解oracle11g新出参数 MEMORY_MAX_TARGET和 MEMORY_TARGET进行自动管理PGA和SGA称之为自动化内存管理(AutomaticMemory Management,AMM)              MEMORY_MAX_TARGET :MEMORY_TARGET所能设定的最大值。非动态可调

大家好,又见面了,我是你们的朋友全栈君。

oracle11g新出参数  MEMORY_MAX_TARGET 和  MEMORY_TARGET 进行自动管理PGA 和SGA 称之为 自动化内存管理(Automatic Memory Management,AMM)              
MEMORY_MAX_TARGET  :MEMORY_TARGET所能设定的最大值。非动态可调                                                                                                                                              
MEMORY_TARGET :操作系统上 Oracle 所能使用的最大内存值。动态参数,MEMORY_TARGET 是PAG 和SGA的总和.memory_target 为 0 是手动
管理,非0为自动管理    
sga_max_size : sga_max_size 是sga的最大值                                                                                                                                                                                                       
sga_target  :  sga_target   是自动和手段管理 sga_target 为0 是手动管理,非0 是自动管理      

 

oracle 11g 引入参数mymory_max_target 和memory_target 就是oracle的新特性自动内存管理,AMM 的引入, 组合出来有 5 种内存管理形式.
自动内存管理(AMM): memory_target=非0,是自动内存管理  ,如果初始化参数 LOCK_SGA = true ,则 AMM 是不可用的。

自动共享内存管理(ASMM): 在memory_target=0 and sga_target=非0 是自动内存管理
手工共享内存管理: memory_target=0 and sga_target=0   指定 share_pool_size 、db_cache_size 等 sga 参数
自动 PGA 管理: memory_target=0 and workarea_size_policy=auto  and PGA_AGGREGATE_TARGET=值
手动 PGA 管理: memory_target=0 and workarea_size_policy=manal  然后指定 SORT_AREA_SIZE 等 PGA 参数,一般不使用手动管理PGA

SQL> show parameter result_cache_size
用来缓存sql语句结果
NAME         TYPE          VALUE
———————————— ——————————— ——————————
client_result_cache_size      big integer         0

 

 

 如果指定了memory_target 而没有指定memory_max_target 重启后,memory_max_target 和memory_target 大小相等
如果指定了memory_max_target 而没有指定 memory_target重启后memory_target 为0

SQL> show parameter memory

NAME                                 TYPE        VALUE
———————————— ———– —————————
hi_shared_memory_address             integer     0
memory_max_target                    big integer 1232M
memory_target                        big integer 1232M
shared_memory_address                integer     0

当设置  memory_max_target < memory_target 时:
SQL> alter system set memory_max_target=1000M scope=spfile;

系统已更改。

SQL> shut immediate
数据库已经关闭。
已经卸载数据库。
ORACLE 例程已经关闭。
SQL>
SQL>
SQL>
SQL> startup
ORA-00837: Specified value of MEMORY_TARGET greater than MEMORY_MAX_TARGET

11g AMM管理方式:                                                                                                                
SQL> select name,bytes/1024/1024 from v$sgainfo;                                                               

NAME                             BYTES/1024/1024                                                                             
——————————– —————                                                                                         
Fixed SGA Size                        1.31111908                                                                              
Redo Buffers                            5.015625                                                                                   
Buffer Cache Size                            496                                                                                    
Shared Pool Size                             216                                                                                    
Large Pool Size                                8                                                                                        
Java Pool Size                                 8                                                                                       
Streams Pool Size                              8                                                                                    
Shared IO Pool Size                            0                                                                                   
Granule Size                                   8                                                                                       
Maximum SGA Size                      742.328125                                                                        
Startup overhead in Shared Pool               64                                                                           

Free SGA Memory Available                      0                                                                             

 SQL> show parameter sga                           

NAME                                 TYPE        VALUE                                               
———————————— ———– ——-                                                     
lock_sga                             boolean     FALSE                                               
pre_page_sga                         boolean     FALSE                                          
sga_max_size                         big integer 744M                                             
sga_target                           big integer 0                                                       

SQL> show parameter memory                                             

  NAME                                TYPE        VALUE                           
———————————— ———– ——-                                 
hi_shared_memory_address             integer     0                       
memory_max_target                    big integer 1232M                  
memory_target                        big integer 1232M                        
shared_memory_address                integer     0                           

从上面的参数可以看出,memory_target 非0 说明 sga和pga是统一自动管理
就不用看sga_target 为0的意义

 

 

在10g管理方式是自动共享内存管理(Automatic Share Memory Manage) ASMM
ASMM 方式管理,把memory_target 设置为0

SQL> alter system set memory_target=0 scope=spfile;

SQL> show parameter memory

NAME                                 TYPE        VALUE
———————————— ———– ———
hi_shared_memory_address             integer     0
memory_max_target                    big integer 0
memory_target                        big integer 0
shared_memory_address                integer     0
说明 AMM管理方式和ASMM管理方式一样
 只要设置memory_target 为 0 是oracle内存手动管理,非0oracle内存自动管理

SQL> show parameter sga

NAME                                 TYPE        VALUE
———————————— ———– ——-
lock_sga                             boolean     FALSE
pre_page_sga                         boolean     FALSE
sga_max_size                         big integer 144M
sga_target                           big integer 144M
说明在memory_target=0的情况下,oracle内存的手动管理,sga_target=144M,sga的自动管理

 

 

 

SQL> show parameter memory

NAME                                 TYPE        VALUE
———————————— ———– ———–
hi_shared_memory_address             integer     0
memory_max_target                    big integer 0
memory_target                        big integer 0
shared_memory_address                integer     0

SQL> alter system set sga_target=0 ;

系统已更改。

SQL> show parameter sga

NAME                                 TYPE        VALUE
———————————— ———– ——————–
lock_sga                             boolean     FALSE
pre_page_sga                         boolean     FALSE
sga_max_size                         big integer 144M
sga_target                           big integer 0

说明在memory_target=0的情况下,oracle内存的手动管理,sga_target=0M,sga是手动管理

 

 

 

 

SQL> show parameter sga

NAME                                 TYPE        VALUE
———————————— ———– ——————————
lock_sga                             boolean     FALSE
pre_page_sga                         boolean     FALSE
sga_max_size                         big integer 144M
sga_target                           big integer 0
SQL> alter   system set sga_target=120;

系统已更改。

SQL> show parameter sga

NAME                                 TYPE        VALUE
———————————— ———– ——————————
lock_sga                             boolean     FALSE
pre_page_sga                         boolean     FALSE
sga_max_size                         big integer 144M
sga_target                           big integer 144M

 

SQL> select component, granule_size/1024/1024 M from v$sga_dynamic_components;

COMPONENT                                                                 M
—————————————————————- ———-
shared pool                                                               4
large pool                                                                4
java pool                                                                 4
streams pool                                                              4
DEFAULT buffer cache                                                      4
KEEP buffer cache                                                         4
RECYCLE buffer cache                                                      4
DEFAULT 2K buffer cache                                                   4
DEFAULT 4K buffer cache                                                   4
DEFAULT 8K buffer cache                                                   4
DEFAULT 16K buffer cache                                                  4

COMPONENT                                                                 M
—————————————————————- ———-
DEFAULT 32K buffer cache                                                  4
Shared IO Pool                                                            4
ASM Buffer Cache                                                          4

已选择14行。

granule size 是 4M大小

 

SQL> alter   system set sga_target=120M;
alter   system set sga_target=120M
*
第 1 行出现错误:
ORA-02097: 无法修改参数, 因为指定的值无效
ORA-00827: 无法将 sga_target 压缩到指定值

 

SQL> alter   system set sga_target=0;

系统已更改。

SQL> show parameter sga

NAME                                 TYPE        VALUE
———————————— ———– ————
lock_sga                             boolean     FALSE
pre_page_sga                         boolean     FALSE
sga_max_size                         big integer 144M
sga_target                           big integer 0

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/133808.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • eclipse安装android_安卓studio怎么打包apk

    eclipse安装android_安卓studio怎么打包apkEclipseandroid开发更改apk名字有以下几步:第一步,修改工程包名在eclipse里,找到项目包和java包(原则上都一样),就可以按”F2″修改名字,随之,源.java也会得到相应的修改;然而每个.java文件都需要把如下图内容,再额外修改一下第二步,修改AndroidManifest.xml文件AndroidManifest.xml里的内容是android工程的相关配置文件。工程文件的解析具体可参考:某鸟教程.第三步,修改Strings.xml文件然后是…

    2022年10月5日
    5
  • 激活函数ReLU、Leaky ReLU、PReLU和RReLU

    激活函数ReLU、Leaky ReLU、PReLU和RReLU“激活函数”能分成两类——“饱和激活函数”和“非饱和激活函数”。sigmoid和tanh是“饱和激活函数”,而ReLU及其变体则是“非饱和激活函数”。使用“非饱和激活函数”的优势在于两点:1.首先,“非饱和激活函数”能解决所谓的“梯度消失”问题。2.其次,它能加快收敛速度。Sigmoid函数需要一个实值输入压缩至[0,1]的范围σ(x)=1/…

    2022年6月15日
    36
  • JDK11安装包(win版)「建议收藏」

    链接:https://pan.baidu.com/s/1S10D5sA8WkYcyOjnE1M5IA提取码:pl26

    2022年4月11日
    46
  • 阿里巴巴JVM调优工具arthas「建议收藏」

    阿里巴巴JVM调优工具arthas「建议收藏」下载下载全量包从Maven仓库下载最新版本,点击下载:从GithubReleases页下载https://github.com/alibaba/arthas/releases用as.sh启动解压后,在文件夹里有as.sh,直接用./as.sh的方式启动:./as.sh打印帮助信息:./as.sh-h用arthas-boot启动或者在解压后,在文件夹里有arthas-boot.jar,直接用java-jar的方式启动:java-jararth

    2022年5月6日
    72
  • 【zTree】zTree根据后台数据生成树并动态设置前面的节点复选框的选中状态

    【zTree】zTree根据后台数据生成树并动态设置前面的节点复选框的选中状态

    2022年3月8日
    132
  • lseek函数的用法

    lseek函数的用法所有打开的文件都有一个当前文件偏移量(currentfileoffset),以下简称为cfo。cfo通常是一个非负整数,用于表明文件开始处到文件当前位置的字节数。读写操作通常开始于cfo,并且使cfo增大,增量为读写的字节数。文件被打开时,cfo会被初始化为0,除非使用了O_APPEND 。   使用lseek函数可以改变文件的cfo。       #in…

    2022年6月17日
    50

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号