电话:0731-83595998
导航

oracle性能调优:Oracle调优命中率等2

来源: 2017-07-21 18:28

  1)共享区字典缓存区命中率

  计算公式:SUM(gets - getmisses - usage -fixed) / SUM(gets)

  命中率应大于0.85

  SQL>select sum(gets-getmisses-usage-fixed)/sum(gets)

  from v$rowcache;

  2)数据高速缓存区命中率

  计算公式:1-(physical reads / (db block gets + consistent gets))

  命中率应大于0.90最好

  SQL>select name,value

  from v$sysstat

  where name in ('physical reads','db block gets','consistent gets');

  3)共享区库缓存区命中率

  计算公式:SUM(pins - reloads) / SUM(pins)

  命中率应大于0.99

  SQL>select sum(pins-reloads)/sum(pins)

  from v$librarycache;

  4)检测回滚段的争用

  SUM(waits)值应小于SUM(gets)值的1%

  SQL>select sum(gets),sum(waits),sum(waits)/sum(gets)

  from v$rollstat;

  5)检测回滚段收缩次数

  SQL>select name,shrinks

  from v$rollstat, v$rollname

  where v$rollstat.usn = v$rollname.usn;

  -----------------------------------------------------------------------------

  几个常用的检查语句

  1. 查找排序最多的SQL:

  SQL>SELECT HASH_VALUE, SQL_TEXT, SORTS, EXECUTIONS

  FROM V$SQLAREA

  ORDER BY SORTS DESC;

  2.查找磁盘读写最多的SQL:

  SQL>SELECT * FROM

  (SELECT sql_text,disk_reads "total disk" , executions "total exec",disk_reads/executions "disk/exec" FROM v$sql

  WHERE executions>0 and is_obsolete='N' ORDER BY 4 desc)

  WHERE ROWNUM< 11 ;

  3.查找工作量最大的SQL(实际上也是按磁盘读写来排序的):

  SQL>select substr(to_char(s.pct, '99.00'), 2) || '%' load,s.executions executes,p.sql_text

  from(select address,disk_reads,executions,pct,rank() over (order by disk_reads desc) ranking from

  (select address,disk_reads,executions,100 * ratio_to_report(disk_reads) over () pct

  from sys.v_$sql

  where command_type != 47)

  where disk_reads > 50 * executions) s,sys.v_$sqltext p

  where s.ranking select executions,disk_reads,buffer_gets,round((buffer_gets-disk_reads)/buffer_gets,2) Hit_radio,round(disk_reads/executions,2) reads_per_run,sql_text

  From v$sqlarea

  Where executions>0 and buffer_gets >0 and (buffer_gets-disk_reads)/buffer_gets< 0.8

  Order by 4 desc;

  5、根据sid查看对应连接正在运行的sql

  SQL>select /*+ push_subq */command_type,sql_text,sharable_mem,persistent_mem,

  runtime_mem,sorts,version_count,loaded_versions,open_versions,users_opening,executions,

  users_executing,loads,first_load_time,invalidations,parse_calls,disk_reads,buffer_gets,

  rows_processed,sysdate start_time,sysdate finish_time,'>'||address sql_address,'N'status

  From v$sqlarea

  Where address=(select sql_address from v$session where sid=&sid);

  ***************Oracle 缓冲区命中率低的分析及解决办法******************

  首先确定下面的查询结果:

  1,缓冲区命中率的查询(是否低于90%):

  select round((1 - sum(decode(name,'physical reads',value,0)) /

  (sum(decode(name,'db block gets',value,0)) + sum(decode(name,'consistent gets',value,0))) ),4) *100 || '%' chitrati

  from v$sysstat;

  2,使用率的查询(有无free状态的数据快。):

  select count(*), status from v$bh group by status ;

  3,相关等待事件的查询(是否有相关等待事件)

  select event,total_waits from v$system_event where event in ('free buffer waits');

  4,当前大小(是否已经很大)

  select value/1024/1024 cache_size from v$parameter where name='db_cache_size'

  5,top等待事件分析(Db file scatered read的比率是否大)

  select event ,total_waits,suml

  from

  (select event,total_waits,round(total_waits/sumt*100,2)||'%' suml

  from

  (select event,total_waits from v$system_event ),

  (select sum(total_waits) sumt from v$system_event)

  order by total_waits desc)

  where rownum< 6

  and event not like 'rdbms%'

  and event not like 'pmon%'

  and event not like 'SQL*Net%'

  and event not like 'smon%';

  6,db_cache_advice建议值(9i后的新特性,可以根据他更好的调整cache_size)

  select block_size,size_for_estimate,size_factor,estd_physical_reads from v$db_cache_advice;

编辑推荐:

下载Word文档

温馨提示:因考试政策、内容不断变化与调整,长理培训网站提供的以上信息仅供参考,如有异议,请考生以权威部门公布的内容为准! (责任编辑:长理培训)

网络课程 新人注册送三重礼

已有 22658 名学员学习以下课程通过考试

网友评论(共0条评论)

请自觉遵守互联网相关政策法规,评论内容只代表网友观点!

最新评论

点击加载更多评论>>

精品课程

更多
10781人学习

免费试听更多

相关推荐
图书更多+
  • 电网书籍
  • 财会书籍
  • 其它工学书籍
拼团课程更多+
  • 电气拼团课程
  • 财会拼团课程
  • 其它工学拼团
热门排行

长理培训客户端 资讯,试题,视频一手掌握

去 App Store 免费下载 iOS 客户端