Oracle資料庫緩衝區命中率(轉)

ba發表於2007-08-16
Oracle資料庫緩衝區命中率(轉)[@more@]1、檢視Oracle資料庫緩衝區命中率

select a.value + b.value "logical_reads", c.value "phys_reads",
round(100 * ((a.value+b.value)-c.value) / (a.value+b.value)) "BUFFER HIT RATIO"
from v$sysstat a, v$sysstat b, v$sysstat c
where a.statistic# = 40 and b.statistic# = 41
and c.statistic# = 42
2、Tags: oracle

資料庫緩衝區命中率:
sql>select value from v$sysstat where name ='physical reads';
value
3714179
sql>select value from v$sysstat where name ='physical reads direct';
value
0
sql>select value from v$sysstat where name ='physical reads direct(lob)';
value
0
sql>select value from v$sysstat where name ='consistent gets';
value
856309623
sql>select value from v$sysstat where name ='db block gets';
value
19847790
這裡命中率的計算應該是
令x=physical reads direct + physical reads direct(lob)
命中率=100-(physical reads -x)/(consistent gets +db block gets -x)*100
通常如果發現命中率低於90%,則應該調整應用可以考慮是否增大資料加

共享池的命中率
sql> select sum(pinhits)/sum(pins)*100 "hit radio" from v$librarycache;
如果共享池的命中率低於95%就要考慮調整應用(通常是沒應用bind var)或者增加記憶體。

關於排序部分
sql> select name,value from v$sysstat where name like '%sort%';
如果我們發現sorts(disk)/(sorts(memory)+sorts(disk))的比例過高,則通常意味著sort_area_size部分記憶體教較小,可考慮調整相應的引數。

關於log_buffer
sql>select name,value from v$sysstat where name in ('redo entries','redo buffer allocation retries');
假如redo buffer allocation retries/redo entries的比例超過1%我們就可以考慮增加log_buffer.

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10617731/viewspace-961596/,如需轉載,請註明出處,否則將追究法律責任。

相關文章