设为首页 收藏本站
查看: 390|回复: 0

[经验分享] 【11g体系结构,4】AMM(内存分配自动管理)

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-9-10 08:43:20 | 显示全部楼层 |阅读模式
一.AMM (automaitc memory managerment)




1.oracle 10g SGA的自动管理 :SGA_TARGET 指定了SGA可以使用的最大内存大小,而SGA中各个内存的大小由Oracle自行控制,不需要人为指定。Oracle 可以随时调节各个区域的大小,使之达到系统性能最佳状态的个最合理大小,并且控制他们之和在SGA_TARGET 指定的值之内。一旦给SGA_TARGET指定值后(默认为0,即没有启动ASMM),就自动启动了ASMM特性。如果不设置SGA_TARGET,则自动共享内存管理功能被禁止


注意:修改sga_target的值不能大于sga_max_size,所以sga_max_siz是sga的管理上限。
SQL> show parameter sga


NAME                                 TYPE        VALUE
------------------------------------ ----------- -------------------------
lock_sga                             boolean     FALSE
pre_page_sga                         boolean     FALSE
sga_max_size                         big integer 416M
sga_target                           big integer 200M





SQL> alter system  set sga_target=500m scope=spfile ;
alter system  set sga_target=500m scope=spfile ;
*
ERROR at line 1:
ORA-02097: parameter cannot be modified because specified value is invalid
ORA-00823: Specified value of sga_target greater than sga_max_size



②.设置了SGA_TARGET后,以下的SGA内存区就可以由ASMM来自动调整:
ASMM只能自动调整5个内存池的大小,它们是:shared pool、buffer cache、large pool、java pool和stream pool。我们不再需要设置shared_pool_size、db_cache_size、large_pool_size、 java_pool_size、streams_pool_size这五个初始化参数。而其他的内存池,比如log buffer、keep buffer cache等仍然需要DBA手工进行调整。


对于SGA_TARGET的限制,它的大小是不能超过SGA_MAX_SIZE的大小的。


#查看sga中各池真实的大小:
SQL> select name,bytes/1024/1024 m from v$sgainfo;

NAME                                      M
-------------------------------- ----------
Fixed SGA Size                   1.27510452
Redo Buffers                     5.78515625
Buffer Cache Size                        80
Shared Pool Size                        148
Large Pool Size                           4
Java Pool Size                            4
Streams Pool Size                         0
Shared IO Pool Size                       0
Granule Size                              4
Maximum SGA Size                   415.0625
Startup overhead in Shared Pool          52

NAME                                      M
-------------------------------- ----------
Free SGA Memory Available               172

12 rows selected.


案例:设置sga_target

SQL> ALTER system SET sga_max_size=1000m scope=spfile;
SQL> ALTER system SET sga_target=1000m scope=spfile;

关闭数据库
shutdown immediate;
启动数据库
startup;


注意:
  http://file:///C:/Users/jyy/Documents/My%20Knowledge/temp/188c9a30-8106-4d22-9f2d-9f45f2034345_4_files/870c6eec-bde3-47c4-8163-145b5e3947a4.jpg
    #修改/dev/shm的大小为2g: 要修改etc/fstab 文件,然后重新挂载一下。
     [iyunv@gc1 ~]vi etc/fstab
     http://file:///C:/Users/jyy/Documents/My%20Knowledge/temp/188c9a30-8106-4d22-9f2d-9f45f2034345_4_files/ab0182d3-59d3-4a75-ac62-1c710511de54.png
          #重新挂载
     http://file:///C:/Users/jyy/Documents/My%20Knowledge/temp/188c9a30-8106-4d22-9f2d-9f45f2034345_4_files/86e718cb-287c-4119-ad8f-3d24b63f3268.png







2.oracle 11g SGA自动管理:①.在Oracle11g中,Oracle 将内存管理的自动化更进了一步,引入了自动内存管理(Automatic Memory Management- AMM)的新特性。



②.Oracle11g 引入了一个新的参数 MEMORY_TARGET。现在只要设置了这个参数,可以不需要设置 SGA_TARGET 和 PGA_AGGREATE_TARGET 两个参数。

只需要设置一个目标内存大小初始化参数( MEMORY_TARGET )  和一个最大内存大小初始化参数( MEMORY_MAX_TARGET),数据库就会根据处理需求在SGA 与实例 PGA 之间动态交换内存。
③.自动内存管理是用两个初始化参数进行配置的:
MEMORY_TARGET:动态控制SGA和PGA时,Oracle总共可以使用的共享内存大小,这个参数是动态的,因此提供给Oracle的内存总量是可以动态增大,也可以动态减小的。它不能超过MEMORY_MAX_TARGET参数设置的大小。默认值是0。

MEMORY_MAX_TARGET:这个参数定义了MEMORY_TARGET最大可以达到而不用重启实例的值,如果没有设置MEMORY_MAX_TARGET值,默认等于MEMORY_TARGET的值。
使用动态内存管理时,SGA_TARGET和PGA_AGGREGATE_TARGET代表它们各自内存区域的最小设置,要让Oracle完全控制内存管理,这两个参数应该设置为0。但并不会因为设置了MEMORY_TARGET,这两个参数就会自动变回0。


④.ORACLE的内存管理参数下图所示:

http://file:///C:/Users/jyy/Documents/My%20Knowledge/temp/188c9a30-8106-4d22-9f2d-9f45f2034345_4_files/b8acaf4d-249b-489c-a25d-4188bdcbb8f5.jpg


3.shared pool的调整:
#查看shared pool 参数 (为0表示shared pool为自动管理)
SQL> show parameter shared_pool_size

NAME                                 TYPE        VALUE
------------------------------------ ----------- -------------------------
shared_pool_size                     big integer 0



#查看shared pool的真实大小
SQL> select name,bytes/1024/1024 m from v$sgainfo;

NAME                                      M
-------------------------------- ----------
Fixed SGA Size                   1.27510452
Redo Buffers                     5.78515625
Buffer Cache Size                        80
Shared Pool Size                        148
Large Pool Size                           4
Java Pool Size                            4
Streams Pool Size                         0
Shared IO Pool Size                       0
Granule Size                              4
Maximum SGA Size                   415.0625
Startup overhead in Shared Pool          52


#调大shared pool 的值
SQL> alter  system set shared_pool_size=160m ;

System altered.
#查询
SQL> select name,bytes/1024/1024 m from v$sgainfo;

NAME                                      M
-------------------------------- ----------
Fixed SGA Size                   1.27510452
Redo Buffers                     5.78515625
Buffer Cache Size                        68
Shared Pool Size                        160
Large Pool Size                           4
Java Pool Size                            4
Streams Pool Size                         0
Shared IO Pool Size                       0
Granule Size                              4
Maximum SGA Size                   415.0625
Startup overhead in Shared Pool          52

NAME                                      M
-------------------------------- ----------
Free SGA Memory Available               172

12 rows selected.
#调小 shared pool的值, 发现shared pool还是160m,所以shared pool 只能调大不能调小。
SQL> alter  system set shared_pool_size=148m;

System altered.

SQL> select name,bytes/1024/1024 m from v$sgainfo;

NAME                                      M
-------------------------------- ----------
Fixed SGA Size                   1.27510452
Redo Buffers                     5.78515625
Buffer Cache Size                        68
Shared Pool Size                        160
Large Pool Size                           4
Java Pool Size                            4
Streams Pool Size                         0
Shared IO Pool Size                       0
Granule Size                              4
Maximum SGA Size                   415.0625
Startup overhead in Shared Pool          52

NAME                                      M
-------------------------------- ----------
Free SGA Memory Available               172

12 rows selected.


二.案例总结:
1.swap区大小设置:关于操作系统,一般Swap区的推荐值为2*RAM。如果物理内存(RAM)很大,不一定非要把Swap设置为2xSwap,通常可以设置Swap = Ram或者小于物理内存(如内存超过32G则完全可以设置Swap为16G )。
如果物理内存(RAM)过小,在系统繁忙期间,产生大量交换无法换到磁盘,就会出现问题。
另外,如果系统物理内存较小,通常设置SGA < 1/2 Ram ,要考虑为Server process 的PGA消耗及OS保留足够的内存空间.  








运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-24588-1-1.html 上篇帖子: 【11g体系结构,6】参数文件和一些参数 下篇帖子: rman 兼容性一览
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表