1 BUFFER命中率 也就是通常所说高速缓存的命中率,这个指标是指通过内存得到访问的数据和所有访问的数据之间的一个比例。 正常指标范围: Buffer命中率正常的指标为:90%-100%,但在数据库繁忙运行期间(批处理应用、数据仓库),Buffer命中率可能低于90%,这是正常的指标。 计算公式: Buffer hit =(1-physical reads cache /(consistent gets from cache + db block gets from cache)) *100 其中: physical reads cache = physical reads - physical reads direct - physical read direct(LOB) consistent gets from cache = consistent gets db block gets from cache = db block gets 可以通过SQL查询数所库性能字典得到数据库高速缓存的命中率 select round((1 - (physical.value - direct.value - lobs.value)/logical.value)*100,2) "Buffer Cache Hit Ratio" from v$sysstat physical,v$sysstat direct,v$sysstat lobs,v$sysstat logical where physical.name ='physical reads' and direct.name ='physical reads direct' and lobs.name ='physical reads direct (lob)' and logical.name ='session logical reads'; 影响因素: 1. Buffer 命中率受Oracle SGA中的data block buffers参数的设置影响 2. 跟Oracle buffer Pool的使用方法有关 3. 把经常使用的小表cache在内存中 4. 调优SQL语句,以养活少访问的数据量 2 LIBRARY命中率 就是通常所说的库缓存的命中率。指的是在Oracle执行SQL语句的过程中,通过内存直接得到对象的命名空间。 正常指标范围: Library命中率正常指标范围为:95%-100% 计算公式: Library hit = sum(pins)/(sum(pins)+sum(reloads)) *100 可以通过SQL查询得到库缓存的命中率 select round(sum(pins -reloads)/sum(pins)*100,2) "Library Cache Hit Ratio" from v$librarycache; 影响因素: 1. Library命中率受Oracle SGA中的shared pool参数设置影响 2. 跟应用软件的开发有密切的关系,特别是共享SQL的使用 3 LATCH命中率 Latch是一种简单的低级串行化机制,用于保护系统全局区中的共享数据结构。如:保护当前正在止访问数据库的用户列表,保护描述缓冲区中的块的数据结构。对于服务器或后台进程来说,必须取得伴随的LATCH才能开始操作或查看共享的数据结构,而在完成后,又必须释放伴随的LATCH,LATCH的实施和操作系统的平台有关,尤其与进程是否需要等待LATCH以及需要等待多长时间有关。 正常指标范围: LATCH命中率正常指标范围为:99%-100% 计算公式: Latch hit = (1 - sum(misses + immediate_misses)/sum(gets+immediate_gets) ) * 100
可以通过SQL查询得到LATCH命中率 select round((1-sum(misses +immediate_misses)/sum(gets + immediate_gets))*100,2) "Latch Hit Ratio" from v$latch; 影响因素: 1. 应用程序SQL是否使用绑定变量 2. Shared_pool_size参数的设置 4 In-Memory Sort命中率 这个指标是指在内存中完成的排序和硬盘上排序的比率 正常指标范围: In-Memory Sort命中率正常指标范围为:99%-100% 计算公式: In-Memory Sort hit= (1 -sorts(disk)/(sorts(disk)+sorts(memory))) * 100
可以通过SQL查询得到In-Memory Sort命中率 select round((1 - disk.value/(disk.value + memory.value))*100,2) "In-Memory Sort" from v$sysstat disk,v$sysstat memory where disk.name ='sorts (disk)' and memory.name ='sorts (memory)'; 影响因素: 1. 数据库参数sort_area_size或pga_aggregate_target的大小 2. 应用程序的SQL语句的写法 5 Buffer NoWait 这个指标是指在缓冲区获取buffer的未等待比率 正常指标范围: Buffer Nowait率正常指标范围为:99%-100% 计算公式: Buffer Nowait = (1- buffer busy wait / session logical reads) * 100 可以通过SQL查询得到Buffer NoWait命中率 select round((1 - busy.value/tol.value)*100,2) "Buffer busy NoWait Ratio" from (select sum(count) value from v$waitstat where class in ('data block','segment header','undo header','undo block')) busy, (select value from v$sysstat where name='session logical reads') tol; 影响因素: 1. db_block_buffers或db_cache_size等参数 2. 增加表的Freelist参数 3. 使用Automatic Segment Storge Management(ASSM)来创建表空间 4. 优化程序使用的SQL语句 6 Redo NoWait 这个指标是指redo缓冲区获取buffer的未等待比率 正常指标范围: Redo Nowait率正常指标范围为:99%-100% 计算公式: Redo Nowait = (1- redo log space requests / reso entries) * 100 可以通过SQL查询得到Redo NoWait命中率 select round((1 - waits.value/redos.value)*100,2) "Redo NoWait Ratio" from v$sysstat waits,v$sysstat redos where waits.name ='redo log space requests' and redos.name ='redo entries'; 影响因素: 1. Log_buffer_size参数设置过小 2. 归档的速度太慢 3. 联机日志文件太小 4. 联机日志文件放在缓慢的磁盘设备上
7 Execute to Parse 这个指标是指数据库的SQL语句执行和分析的比例 正常指标范围: Execute to Parse 越接近100%越好 计算公式: Execute to Parse = (1- Parses / Executions) * 100 可以通过SQL查询得到Execute to Parse率 select round((1 - hard.value/total.value)*100,2) "Execute to Parse Ratio" from v$sysstat hard,v$sysstat total where hard.name ='parse count (hard)' and total.name ='parse count (total)';
影响因素: 1. Share_pool_size参数的大小 2. 最重要的影响因素是应用程是否使用了绑定变量 8 Parse CPU to Pares Elapsed 这个指标是指数据库用在分析的CPU的时间和分析完成CPU时间对比 正常指标范围: Parse CPU to Parse Elapsed 越接近100%越好 计算公式: Parse CPU to Parse Elapsed =(1-Parses time cpu/Parses time elapsed)* 100 可以通过SQL查询得到Parse CPU to Parse Elapsed e率 select round((1 - cpu.value/total.value)*100,2) "Parse CPU to Parse Elapsed Ratio" from v$sysstat cpu,v$sysstat total where cpu.name ='parse time cpu' and total.name ='parse time elapsed'; 影响因素: 1. 如果这个比例很低,说明分析过程中CPU等待了其它的资源 9 Non-Parse CPU 这个指标是指数据库用在非分析的过程中CPU的等待了其它的资源 正常指标范围: Non-Parse CPU越接近100%越好 计算公式: Non-Parse CPU = (1- parse time cpu / CPU used by this session) * 100
可以通过SQL查询得到Non-Parse CPU率 select round((1 - parse.value/total.value)*100,2) "Non-Parse CPU Ratio" from v$sysstat parse,v$sysstat total where parse.name ='parse time cpu' and total.name ='CPU used by this session' 影响因素: 1. 如果这个比例很低,说明CPU用在分析SQL语句上面消耗了很多CPU时间,可能是没有用绑定变量 10 Rollback segment竟争情况 这个是指等待rollback segment的header比率 正常指标范围: rollback segment等待率比率越小越好 计算公式: rollback segment = (waits/gets) * 100 可以通过SQL查询得到rollback segment等待率 select name,waits,gets,round(waits/gets*100,2) "Ratio" from v$rollstat a,v$rollname b where a.usn = b.usn; 影响因素: 1. 回滚段竟争情况受回滚段size的设置影响 2. 跟应用软件的有关,特别是long runnig time transaction的使用 11 Tablespace的I/O比例 这个是指表空间的所使用的I/O比例 正常指标范围: Tablespace I/O越小越好 计算公式: 可以通过SQL查询得到Tablespace I/O情况 select df.tablespace_name,sum(f.phyrds),sum(f.phyblkrd), sum(f.phywrts),sum(f.phyblkwrt) from v$filestat f,dba_data_files df where f.file#=df.file_id group by df.tablespace_name order by df.tablespace_name; 影响因素: 1. Tablespace的I/O情况受db_block_size参数的设置影响 2. 跟数据文件的磁盘分布有密切关系 12 Datafile 的I/O比例 这个是指访问数据文件所使用的I/O比例 正常指标范围: Datafile I/O越小越好 计算公式: 可以通过SQL查询得到Datafile I/O情况 select df.name,sum(f.phyrds),sum(f.phyblkrd),sum(f.phywrts),sum(f.phyblkwrt) from v$filestat f,v$datafile df where f.file#=df.file# group by df.name order by df.name; 影响因素: 1. Datafile的I/O情况受db_block_size参数的设置影响 2. 跟数据文件的磁盘分布有密切关系 13 重做日志缓存区命中率 这个是指重做日志缓存区的命中率 正常指标范围: 重做日志缓存区的命中率越大越好,应大于90% 计算公式: 可以通过SQL查询得到日志缓存区的命中率 select name,gets,misses,immediate_gets,immediate_misses, 100 - round(decode(gets,0,0,misses/gets *100),2) ratio1, 100 - round(decode(immediate_gets+immediate_misses,0,0,immediate_misses/ (immediate_gets+immediate_misses)*100),2) ratio2 from v$latch where name in ('redo allocation','redo copy'); 影响因素: 1. 受log_buffer_size设置影响 2. 跟应用软件的有关,特别是共享SQL的使用 14 碎片程度 这个是指数据库中自由空间碎片FSFI--Free Space Fragmentation Index (自由空间碎片索引)值来直观体现 正常指标范围: FSFI越大越好,应大于30% 计算公式: FSFI=100*SQRT(max(extent)/sum(extents))*1/SQRT(SQRT(count(extents))) 可以通过SQL查询得到日志缓存区的命中率 select tablespace_name,sqrt(max(blocks)/sum(blocks))* (100/sqrt(sqrt(count(blocks)))) FSFI from dba_free_space group by tablespace_name order by 1tablespace_name; 影响因素: 1. 碎片情况受db_block_size,segment_size的设置影响 2. 跟数据块设置大小,段的设置大小有密切的关系
|