Oracle 11g AMM与ASMM切换

Oracle 11g AMM与ASMM切换现在的Oracle正在往智能化方向发展。如果我们现在找一些8i/9i时代的Oracle书籍,怎么样配置合适的数据库各内存池大小是非常重要的话题。但是进入10g之后,自动内存池调节成为一个重要Oracle特性。在10g时,Oracle推出了ASMM(AutomaticSharedMemoryManagement),实现了OracleSGA和PGA内部结构的自调节。进入11g之后,AMM(A…

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

现在的Oracle正在往智能化方向发展。如果我们现在找一些8i/9i时代的Oracle书籍,怎么样配置合适的数据库各内存池大小是非常重要的话题。但是进入10g之后,自动内存池调节成为一个重要Oracle特性。 在10g时,Oracle推出了ASMM(Automatic Shared Memory Management),实现了Oracle SGA和PGA内部结构的自调节。进入11g之后,AMM(Automatic Memory Management)实现了参数MEMORY_TARGET,将SGA和PGA的规划全部统筹起来对待。 默认情况下,Oracle 11g是使用AMM的。我们在安装过程中,指定Oracle使用内存的百分比,这个取值就作为MEMORY_TARGET和MEMORY_MAX_TARGET的初始取值使用。如果这两个参数设置为非零取值,那么Oracle就是采用AMM管理策略的。 同时,如果我们设置这两个参数为0,则AMM自动关闭。对应的SGA_TARGET、PGA_AGGREGATE_TARGET参数取值非零之后,Oracle自动退化使用ASMM特性。 本篇简单介绍一下AMM和ASMM的相互切换。
1、实验环境介绍我们选择11.2.0.3进行试验,当前状态为ASMM。SQL> select * from v$version;BANNER——————————————————————————–Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 – ProductionPL/SQL Release 11.2.0.3.0 – ProductionCORE        11.2.0.3.0         Production
当前MEMORY_TARGET设置为零,AMM没有启用。SQL> show parameter target NAME                                 TYPE        VALUE———————————— ———– ——————————archive_lag_target                   integer     0db_flashback_retention_target        integer     1440fast_start_io_target                 integer     0fast_start_mttr_target               integer     0memory_max_target                    big integer 0memory_target                        big integer 0parallel_servers_target              integer     16pga_aggregate_target                 big integer 108Msga_target                           big integer 252M

 

2、从ASMM到AMM

在11g中,如果使用ASMM,对应的内存共享段是真实的共享段。[oracle@SimpleLinux ~]$ ipcs -m —— Shared Memory Segments ——–key        shmid      owner      perms      bytes      nattch     status     0x00000000 32768      oracle    640        4194304    32                     0x00000000 65537      oracle    640        260046848  32                     0x01606d30 98306      oracle    640        4194304    32  
下面进行参数的调整,这里笔者有一个建议,很多时候启动umount阶段故障都是由于不当的参数修改造成的。在进行参数修改之前,可以使用create pfile进行一下参数备份,可以加快故障出现时候的系统修复速度。SQL> show parameter spfileNAME                                 TYPE        VALUE———————————— ———– ——————————spfile                               string      /u01/app/oracle/dbs/spfileora11g.ora SQL> create pfile from spfile;Done
修改系统参数,将sga和pga的target值设置为0,memory的target设置非0。注意,这个过程很多参数是静态的参数,可以都在spfile可见性中进行修改,之后重启服务器生效。SQL> alter system set memory_max_target=360m scope=spfile;System altered SQL> alter system set memory_target=360m scope=spfile;System altered SQL> alter system set sga_target=0m scope=spfile;System altered SQL> alter system set sga_max_size=0 scope=spfile;System altered SQL> alter system set pga_aggregate_target=0 scope=spfile;System altered
重新启动数据库服务器,查看参数配置。SQL> conn / as sysdbaConnected.SQL> startup forceORACLE instance started. Total System Global Area  263651328 bytesFixed Size                  1344284 bytesVariable Size             176164068 bytesDatabase Buffers           83886080 bytesRedo Buffers                2256896 bytesDatabase mounted.Database opened. SQL> show parameter targetNAME                                 TYPE        VALUE———————————— ———– ——————————archive_lag_target                   integer     0db_flashback_retention_target        integer     1440fast_start_io_target                 integer     0fast_start_mttr_target               integer     0memory_max_target                    big integer 360Mmemory_target                        big integer 360Mparallel_servers_target              integer     16pga_aggregate_target                 big integer 0sga_target                           big integer 0
AMM启动之后,系统共享段变为“虚拟”共享段。[oracle@SimpleLinux dbs]$ ipcs -m —— Shared Memory Segments ——–key        shmid      owner      perms      bytes      nattch     status     0x00000000 163840     oracle    640        4096       0                      0x00000000 196609     oracle    640        4096       0                      0x01606d30 229378     oracle    640        4096       0  
3、从AMM到ASMM下面是如何从AMM到ASMM。要完全关闭AMM,一定将MEMORY_TARGET和MEMORY_MAX_TARGET都设置为0才行。SQL> alter system set memory_max_target=0 scope=spfile;System altered SQL> alter system set memory_target=0 scope=spfile;System altered SQL> alter system set pga_aggregate_target=100m scope=spfile;System altered SQL> alter system set sga_target=260m scope=spfile;System altered SQL> alter system set sga_max_size=260m scope=spfile;System altered
注意,此时如果重新启动系统,会报错。SQL> startup forceORA-00843: Parameter not taking MEMORY_MAX_TARGET into accountORA-00849: SGA_TARGET 272629760 cannot be set to more than MEMORY_MAX_TARGET 0.SQL>
这个问题的原因是Oracle启动过程中对于参数的内部检查。因为MEMORY_MAX_TARGET被“显示”的赋值,与SGA_TARGET赋值相冲突。 解决的方法就是使用参数默认值。创建出pfile之后,将显示赋值为0的MEMORY_TARGET和MEMORY_MAX_TARGET记录行删除掉。再利用pfile启动数据库,重建spfile。
SQL> create pfile from spfile  2  ; File created. –修改前*.db_recovery_file_dest=’/u01/app/fast_recovery_area’*.db_recovery_file_dest_size=10737418240*.diagnostic_dest=’/u01/app’*.dispatchers='(PROTOCOL=TCP) (SERVICE=ora11gXDB)’*.log_checkpoints_to_alert=TRUE*.memory_max_target=0*.memory_target=0*.open_cursors=300*.pga_aggregate_target=104857600*.processes=150 –修改后*.db_recovery_file_dest=’/u01/app/fast_recovery_area’*.db_recovery_file_dest_size=10737418240*.diagnostic_dest=’/u01/app’*.dispatchers='(PROTOCOL=TCP) (SERVICE=ora11gXDB)’*.log_checkpoints_to_alert=TRUE*.open_cursors=300*.pga_aggregate_target=104857600*.processes=150*.remote_login_passwordfile=’EXCLUSIVE’
使用pfile启动数据库,重建spfile。SQL> conn / as sysdbaConnected to an idle instance.SQL> startup pfile=/u01/app/oracle/dbs/initora11g.oraORACLE instance started. Total System Global Area  272011264 bytesFixed Size                  1344372 bytesVariable Size             176163980 bytesDatabase Buffers           88080384 bytesRedo Buffers                6422528 bytesDatabase mounted.Database opened.SQL> show parameter target NAME                                 TYPE        VALUE———————————— ———– ——————————archive_lag_target                   integer     0db_flashback_retention_target        integer     1440fast_start_io_target                 integer     0fast_start_mttr_target               integer     0memory_max_target                    big integer 0memory_target                        big integer 0parallel_servers_target              integer     16pga_aggregate_target                 big integer 100Msga_target                           big integer 260M SQL> create spfile from pfile  2  ; File created.
重新启动之后,ASMM切换完成。
SQL> startup forceORACLE instance started. Total System Global Area  272011264 bytesFixed Size                  1344372 bytesVariable Size             176163980 bytesDatabase Buffers           88080384 bytesRedo Buffers                6422528 bytesDatabase mounted.Database opened. –真实的共享内存段结构[oracle@SimpleLinux dbs]$ ipcs -m —— Shared Memory Segments ——–key        shmid      owner      perms      bytes      nattch     status     0x00000000 425984     oracle    640        8388608    25                     0x00000000 458753     oracle    640        264241152  25                     0x01606d30 491522     oracle    640        4194304    25  –HugePage使用情况[oracle@SimpleLinux dbs]$ grep Huge /proc/meminfoHugePages_Total:    67HugePages_Free:      1HugePages_Rsvd:      0Hugepagesize:     4096 kB[oracle@SimpleLinux dbs]$
4、结论AMM和ASMM是我们管理数据库非常重要的工具,借助自我调节的机制,我们可以做到数据库自我管理。11g的AMM应该说是很方便的,但是在一些情况下,如HugePage,我们可能需要切换回ASMM。权当记录,留需要的朋友待查。

 转。

转载于:https://www.cnblogs.com/andy6/p/5856349.html

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

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/135711.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 电商用户行为数据分析系统的设计与实现_基于大数据的用户行为分析

    电商用户行为数据分析系统的设计与实现_基于大数据的用户行为分析前言本文针对淘宝app的运营数据,以行业常见指标对用户行为进行分析,包括一、提出问题1.电商常用分析体系2.电商常用分析指标3.本次分析的业务问题以及分析逻辑本次想通过对淘宝用户行为数据的分析,解决以下业务问题:以下为分析逻辑和用到适用的业务指标:…

  • 金山词霸2009牛津版完整激活成功教程版+绿色精简版下载

    金山词霸2009牛津版完整激活成功教程版+绿色精简版下载山软件推出了最新的《金山词霸2009牛津版》了!这次金山词霸与牛津合作,一次性增加6本牛津词典,这在牛津在全球的翻译软件合作伙伴中也属首次,实属不容易呢,可以说提升了金山词霸在翻译软件类中的权威和经典的形象了。    这次《金山词霸2009牛津版》里面内置了6本牛津词典:《新牛津英汉双解大词典》、《新牛津美语大词典》、《牛津英语习语词典》、《牛津短语动词词典》、《牛津英语搭配词典》、《牛津英语同义

  • vuejs 和 element 搭建的一个后台管理界面

    vuejs 和 element 搭建的一个后台管理界面

    2021年10月11日
  • 18ch_ios14.8 18h17

    18ch_ios14.8 18h1718.2线程和进程18.2.1什么是进程?18.2.1什么是进程?计算机程序只不过是磁盘中可执行的,二进制的数据。它们只有在被读取到内存中,被操作系统调用的时候才开始它们的生命周期。进程(重量级

  • java tess4j训练库_Java 验证码识别库 Tess4j 学习

    java tess4j训练库_Java 验证码识别库 Tess4j 学习Java验证码识别库Tess4j学习【在用java的Jsoup做爬虫爬取数据时遇到了验证码识别的问题(基于maven),找了网上挺多的资料,发现Tess4j可以自动识别验证码,在这里简单记录下学习过程及遇到的一些问题。】步骤:需要在步骤一的tessdata文件中加入相关语言包(训练文件),在这里下载:https://github.com/tesseract-ocr/tessdata,如果是简…

  • 一个诡异的 JedisConnectionException: Connection refused 问题

    点击上方☝Java编程技术乐园,轻松关注!及时获取有趣有料的技术文章做一个积极的人编码、改bug、提升自己我有一个乐园,面向编程,春暖花开!出现问题我遇到的一个问题,在连接redis的时…

发表回复

您的电子邮箱地址不会被公开。

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