oracle数据库优化之系统全局区

oracle数据库优化之系统全局区

ID:8966702

大小:22.25 KB

页数:10页

时间:2018-04-13

oracle数据库优化之系统全局区_第1页
oracle数据库优化之系统全局区_第2页
oracle数据库优化之系统全局区_第3页
oracle数据库优化之系统全局区_第4页
oracle数据库优化之系统全局区_第5页
资源描述:

《oracle数据库优化之系统全局区》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、Oracle数据库优化之系统全局区(SGA)调整操作系统的内存需求  减少页的换入换出;  将SGA置于主存之中  使用SGA的主要目的是为了在内存中存储数据,以利于快速访问。通过设置初始化参数PRE_PAGE_SGA=YES,在数据库启动时,可以将整个SGA读入内存,这样会减少在启动后ORACLE达到全部性能的总的时间。  使用如下命令可以查看SGA所分配的内存以及其内部的结构:  SVRMGR>SHOWSGA  TotalSystemGlobalArea107720688bytes  FixedSize69616bytes  VariableSize90701824byt

2、es  DatabaseBuffers16777216bytes  RedoBuffers172032bytes  为单个用户分配足够的内存  调整redolog缓冲区  参数LOG_BUFFER指定了REDOLOG的缓冲区的保留大小。LOG写进程(LGWR)在该缓冲区被填充时总是运行的,在新的LOG进入缓冲区时,原来的LOG应已经写入磁盘。  调整私有sql和pl/sql区  标识不必要的语法分析调用  1.在sql跟踪工具有效时运行应用  2.查看视图V$SQLAREAview  SVRMGR>selectsql_text,parse_calls,executionsfr

3、omv$sqlarea;  如果parse_calls值接近execution值,可能就是不断地对sql语句进行语法分析  3.执行如下查询:  select*fromv$statnamewherenamein(‘parse_count(hard)’,’execute_count’);  其结果类似于:  statistic#,name  ----------------------------------  100parse_count  90execute_count  然后执行如下查询:  select*fromv$sesstatwherestatistics#in(9

4、0,100)orderbyvalue,sid;  减少不必要的语法分析调用  初始化参数open_cursors的最大值依赖于操作系统,最少值为5调整共享池  数据字典或库快存的没有命中,其开销大大多于缓冲快存的没有命中,因此,首先应该为共享池分配足够的空间。  使用如下语句可以确定库快存和数据字典快存的命中率:  select(sum(pins-reloads))/sum(pins)“LibCache”fromv$librarycache;  select(sum(gets-getmisses-usage-fixed))/sum(gets)“RowCache”fromv$l

5、ibrarycache;  共享池中的自由内存可以查看:  select*fromv$sgastatwherename=’freememory’;  当然,如果共享池满了并不一定存在问题,只要上面所说的比率接近于1,就不需要增加共享池大小;  如果自由内存接近于0而且库快存或数据字典快存的命中率小于0.95,那么需要增加共享池的大小。  调整LibraryCache  1.检查库快存的活动  selectsum(pins)“Executions”,sum(reloads)”CacheMisseswhileExecuting”fromv$librarycache;  “Exec

6、utions”列指明sql语句,pl/sql块和实体定义被访问执行了的次数,”CacheMisseswhileExecuting”指明其中没有命中的次数。  2.减少库快存的非命中  1、分配更多的库快存(可以增加初始化参数sharedpoolsize的值;为了利用增加的共享sql区,增加初始化参数opencursors的值);  2、尽可能使用标准的sql语句(sql语句或pl/sql块必须一致,包括字符和空格;sql语句或pl/sql块中对schema实体的引用必须解析到同一schema的同一对象;sql语句中试用的变量的名字和数据类型必须匹配;sql语句必须使用相同的优

7、化方法和优化目标);  尽可能使用标准的sql语句,策略:  语句中尽量使用变量而不要使用常量  确保应用用户不会改变优化方法和目标  标准化的变量命名和空格转换  尽可能使用存储过程  3、使用cursor_space_for_time加速共享sql区的访问:该参数指定是否共享sql区可以释放,如果为false(默认值),一个共享sql区就可以被释放;如果为true,一个共享的sql区只存在所有与其相关的游标关闭后才可以被释放。  如果库快存在语句执行时有非命中,不要将其设置为true,否则对新的sq

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。