当前位置:首页 > 全部子站 > IT > Oracle

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

来源:长理培训发布时间:2017-07-21 18:28:19

  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;

责编:周盼盼

发表评论(共0条评论)
请自觉遵守互联网相关政策法规,评论内容只代表网友观点,发表审核后显示!

国家电网校园招聘考试直播课程通关班

  • 讲师:刘萍萍 / 谢楠
  • 课时:160h
  • 价格 4580

特色双名师解密新课程高频考点,送国家电网教材讲义,助力一次通关

配套通关班送国网在线题库一套

课程专业名称
讲师
课时
查看课程

国家电网招聘考试录播视频课程

  • 讲师:崔莹莹 / 刘萍萍
  • 课时:180h
  • 价格 3580

特色解密新课程高频考点,免费学习,助力一次通关

配套全套国网视频课程免费学习

课程专业名称
讲师
课时
查看课程
在线题库
面授课程更多>>
图书商城更多>>
在线报名
  • 报考专业:
    *(必填)
  • 姓名:
    *(必填)
  • 手机号码:
    *(必填)
返回顶部