oracle基础教程之设置系统全局区sga命令,当我们明白了这些在sga中很重要的参数时,才能游刃有余的分配我们有限的内存空间,使我
今天简单介绍一下sga 的设置方法
1.sga_target 参数
alter system set sga_target = 40000m scope=both;
特性:
1).asmm 自动共享内存管理
答:sga_target参数控制asmm(自动共享内存管理)是oracle一个新特性,但是它的含义和sga_max_size的一样,也表示sga最大的大小,于是它也就有了一个限制,那就是它的大小不能大于sga_max_size的大小,一旦给sga_target指定值后(默认为0,即没有启动asmm),就自动启动了asmm特性
2).sga_target 与sga_max_size关系
答:即当sga_target3).sga_target 动态参数
答:sga_target是可以在本实例内动态修改的,不用重启数据库实例,所谓的动态参数是指可以直接修改即在内存生效,不用重启数据库来加载参数文件生效。
4).asmm 自动共享内存管理会影响哪些内存区呢
答:当启用oracle的asmm新特性以后,也不是sga的所有内存区的大小都开始动态共享起来,只有以下的这些区的内存大小可动态共享,而sga中的其他区域的内存大小仍然是固定不共享的
* buffer cache (db_cache_size)
* shared pool (shared_pool_size)
* large pool (large_pool_size)
* java pool (java_pool_size)
* streams pool (streams_pool_size)
2.sga_max_size参数
alter system set sga_max_size=40000m scope=spfile;
特性:
1).sga_max_size静态参数
它用来控制sga使用虚拟内存的最大大小,当实例启动后,各个内存区只分配实例所需要的最小大小,在随后的运行过程中,再根据需要扩展他们的大小,而他们的总和大小受到了sga_max_size的限制。“修改sga_max_size的大小,必须要重新启动数据库实例”,因为是静态参数。所谓静态参数是指修改之后即在spfile参数文件里生效,没有在内存里生效,所以必须重启数据库来加载参数文件使其生效
3.db_cache_size参数【数据库缓冲区高速缓存】
alter system set db_cache_size=2000m scope=both;
1).此参数是一个动态参数,用于缓存数据库中正在使用的“有效数据”的内存区,此内存区的大小对数据的检索速度有很大的影响,如果检索的数据在此区内可以找到,那么要比间接到硬盘中找要快的多。所以在系统稳定后可以静态设置此缓冲区的值
4.scope =【memory | spfile | both】
1).如果scope=memory 说明修改的参数只在内存中生效,重启数据库后恢复到原来状态值【用于修改动态参数】
2).如果scope=spfile 说明修改的参数只在参数文件中生效,修改后当前环境是不生效的,必须重启数据库来加载参数文件使其生效【用于修改静态参数】
3).如果scope=both 说明修改的参数在当前环境(内存)和spfile(参数文件)都生效,both=memory+spfile,修改后当前环境生效,重启数据库后也生效。
小结:当我们明白了这些在sga中很重要的参数时,才能游刃有余的分配我们有限的内存空间,使我们的系统的性能最大化,,让oracle跑的更快、更好。
相关阅读:
oracle的sga
oracle sga 自动管理特性(sga_target参数)
aix平台oracle启用sga大页面(large page)
修改oracle数据库sga和pga大小
oracle 10g参数调整(processes和sga)