欢迎来到天天文库
浏览记录
ID:50669536
大小:51.55 KB
页数:10页
时间:2020-03-07
《Oracle数据库优化之系统全局区.docx》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、Oracle数据库优化之系统全局区(SGA)调整操作系统的内存需求 减少页的换入换出; 将SGA置于主存之中 使用SGA的主要目的是为了在内存中存储数据,以利于快速访问。通过设置初始化参数PRE_PAGE_SGA=YES,在数据库启动时,可以将整个SGA读入内存,这样会减少在启动后ORACLE达到全部性能的总的时间。 使用如下命令可以查看SGA所分配的内存以及其内部的结构: SVRMGR>SHOWSGA TotalSystemGlobalArea107720688bytes FixedSize696
2、16bytes VariableSize90701824bytes DatabaseBuffers16777216bytes RedoBuffers172032bytes 为单个用户分配足够的内存 调整redolog缓冲区 参数LOG_BUFFER指定了REDOLOG的缓冲区的保留大小。LOG写进程(LGWR)在该缓冲区被填充时总是运行的,在新的LOG进入缓冲区时,原来的LOG应已经写入磁盘。 调整私有sql和pl/sql区 标识不必要的语法分析调用 1.在sql跟踪工具有效时运行应用 2.查
3、看视图V$SQLAREAview SVRMGR>selectsql_text,parse_calls,executionsfromv$sqlarea; 如果parse_calls值接近execution值,可能就是不断地对sql语句进行语法分析 3.执行如下查询: select*fromv$statnamewherenamein(‘parse_count(hard)’,’execute_count’); 其结果类似于: statistic#,name ------------------------
4、---------- 100parse_count 90execute_count 然后执行如下查询: select*fromv$sesstatwherestatistics#in(90,100)orderbyvalue,sid; 减少不必要的语法分析调用 初始化参数open_cursors的最大值依赖于操作系统,最少值为5调整共享池 数据字典或库快存的没有命中,其开销大大多于缓冲快存的没有命中,因此,首先应该为共享池分配足够的空间。 使用如下语句可以确定库快存和数据字典快存的命中率: sele
5、ct(sum(pins-reloads))/sum(pins)“LibCache”fromv$librarycache; select(sum(gets-getmisses-usage-fixed))/sum(gets)“RowCache”fromv$librarycache; 共享池中的自由内存可以查看: select*fromv$sgastatwherename=’freememory’; 当然,如果共享池满了并不一定存在问题,只要上面所说的比率接近于1,就不需要增加共享池大小; 如果自由内存接近于
6、0而且库快存或数据字典快存的命中率小于0.95,那么需要增加共享池的大小。 调整LibraryCache 1.检查库快存的活动 selectsum(pins)“Executions”,sum(reloads)”CacheMisseswhileExecuting”fromv$librarycache; “Executions”列指明sql语句,pl/sql块和实体定义被访问执行了的次数,”CacheMisseswhileExecuting”指明其中没有命中的次数。 2.减少库快存的非命中 1、分配更多的
7、库快存(可以增加初始化参数sharedpoolsize的值;为了利用增加的共享sql区,增加初始化参数opencursors的值); 2、尽可能使用标准的sql语句(sql语句或pl/sql块必须一致,包括字符和空格;sql语句或pl/sql块中对schema实体的引用必须解析到同一schema的同一对象;sql语句中试用的变量的名字和数据类型必须匹配;sql语句必须使用相同的优化方法和优化目标); 尽可能使用标准的sql语句,策略: 语句中尽量使用变量而不要使用常量 确保应用用户不会改变优化方法和目标
8、 标准化的变量命名和空格转换 尽可能使用存储过程 3、使用cursor_space_for_time加速共享sql区的访问:该参数指定是否共享sql区可以释放,如果为false(默认值),一个共享sql区就可以被释放;如果为true,一个共享的sql区只存在所有与其相关的游标关闭后才可以被释放。 如果库快存在语句执行时有非命中,不要将其设置为true,否则对新的sq
此文档下载收益归作者所有