`

学习动态性能表(一)--v$sysstat

阅读更多

  按照OracleDocument中的描述,v$sysstat存储自数据库实例运行那刻起就开始累计全实例(instance-wide)的资源使用情况。

 

类似于v$sesstat,该视图存储下列的统计信息:

1>.事件发生次数的统计(如:user commits)

2>.数据产生,存取或者操作的total(如:redo size)

3>.如果TIMED_STATISTICS值为true,则统计花费在执行操作上的总时间(如:CPU used by this session)

 

v$sysstat视图常用列介绍:

l  STATISTIC#: 标识

l  NAME: 统计项名称

l  VALUE: 资源使用量

该视图还有一列class-统计类别但极少会被使用,各类信息如下:

1 代表事例活动

2 代表Redo buffer活动

4 代表锁

8 代表数据缓冲活动

16 代表OS活动

32 代表并行活动

64 代表表访问

128 代表调试信息

注意:Statistic#的值在不同版本中各不相同,使用时要用Name做为查询条件而不要以statistic#的值做为条件。

 

使用v$sysstat中的数据

 

  该视图中数据常被用于监控系统性能。如buffer cache命中率、软解析率等都可从该视图数据计算得出。

  该视图中的数据也被用于监控系统资源使用情况,以及系统资源利用率的变化。正因如此多的性能数据,检查某区间内系统资源使用情况可以这样做,在一个时间段开始时创建一个视图数据快照,结束时再创建一个,二者之间各统计项值的不同(end value - begin value)即是这一时间段内的资源消耗情况。这是oracle工具的常用方法,诸如Statspack以及BSTAT/ESTAT都是如此。

  为了对比某个区间段的数据,源数据可以被格式化(每次事务,每次执行,每秒钟或每次登陆),格式化后数据更容易从两者中鉴别出差异。这类的对比在升级前,升级后或仅仅想看看一段时间内用户数量增长或数据增加如何影响资源使用方面更加实用。

  你也可以使用v$sysstat数据通过查询v$system_event视图来检查资源消耗和资源回收。

 

V$SYSSTAT中的常用统计

 

  V$SYSSTAT中包含多个统计项,这部分介绍了一些关键的v$sysstat统计项,在调优方面相当有用。下列按字母先后排序:

 

数据库使用状态的一些关键指标:

l  CPU used by this session:所有sessioncpu占用量,不包括后台进程。这项统计的单位是百分之x.完全调用一次不超过10ms

l  db block changes:那部分造成SGA中数据块变化的insert,updatedelete操作数 这项统计可以大概看出整体数据库状态。在各项事务级别,这项统计指出脏缓存比率。

l  execute count:执行的sql语句数量(包括递归sql)

l  logons current:当前连接到实例的Sessions。如果当前有两个快照则取平均值。

l  logons cumulative:自实例启动后的总登陆次数。

l  parse count (hard):在shared pool中解析调用的未命中次数。当sql语句执行并且该语句不在shared pool或虽然在shared pool但因为两者存在部分差异而不能被使用时产生硬解析。如果一条sql语句原文与当前存在的相同,但查询表不同则认为它们是两条不同语句,则硬解析即会发生。硬解析会带来cpu和资源使用的高昂开销,因为它需要oracleshared pool中重新分配内存,然后再确定执行计划,最终语句才会被执行。

l  parse count (total):解析调用总数,包括软解析和硬解析。当session执行了一条sql语句,该语句已经存在于shared pool并且可以被使用则产生软解析。当语句被使用(即共享) 所有数据相关的现有sql语句(如最优化的执行计划)必须同样适用于当前的声明。这两项统计可被用于计算软解析命中率。

l  parse time cpu:总cpu解析时间(单位:10ms)。包括硬解析和软解析。

l  parse time elapsed:完成解析调用的总时间花费。

l  physical readsOS blocks read数。包括插入到SGA缓存区的物理读以及PGA中的直读这项统计并非i/o请求数。

l  physical writes:从SGA缓存区被DBWR写到磁盘的数据块以及PGA进程直写的数据块数量。

l  redo log space requests:在redo logs中服务进程的等待空间,表示需要更长时间的log switch

l  redo sizeredo发生的总次数(以及因此写入log buffer),以byte为单位。这项统计显示出update活跃性。

l  session logical reads:逻辑读请求数。

l  sorts (memory) and sorts (disk)sorts(memory)是适于在SORT_AREA_SIZE(因此不需要在磁盘进行排序)的排序操作的数量。sorts(disk)则是由于排序所需空间太大,SORT_AREA_SIZE不能满足而不得不在磁盘进行排序操作的数量。这两项统计通常用于计算in-memory sort ratio

l  sorts (rows): 列排序总数。这项统计可被'sorts (total)'统计项除尽以确定每次排序的列。该项可指出数据卷和应用特征。

l  table fetch by rowid:使用ROWID返回的总列数(由于索引访问或sql语句中使用了'where rowid=&rowid'而产生)

l  table scans (rows gotten):全表扫描中读取的总列数

l  table scans (blocks gotten):全表扫描中读取的总块数,不包括那些split的列。

l  user commits + user rollbacks:系统事务起用次数。当需要计算其它统计中每项事务比率时该项可以被做为除数。例如,计算事务中逻辑读,可以使用下列公式:session logical reads / (user commits + user rollbacks)

 

注:SQL语句的解析有软解析soft parse与硬解析hard parse之说,以下是5个步骤:

1:语法是否合法(sql写法)

2:语义是否合法(权限,对象是否存在)

3:检查该sql是否在共享池中存在

-- 如果存在,直接跳过45,运行sql. 此时算soft parse

4:选择执行计划

5:产生执行计划

-- 如果5个步骤全做,这就叫hard parse.

 

注意物理I/O

 

  oracle报告物理读也许并未导致实际物理磁盘I/O操作。这完全有可能因为多数操作系统都有缓存文件,可能是那些块在被读取。块也可能存于磁盘或控制级缓存以再次避免实际I/OOracle报告有物理读也许仅仅表示被请求的块并不在缓存中。

 

V$SYSSTAT得出实例效率比(Instance Efficiency Ratios)

 

下列是些典型的instance efficiency ratios v$sysstat数据计算得来,每项比率值应该尽可能接近1

 

l  Buffer cache hit ratio:该项显示buffer cache大小是否合适。

公式:1-((physical reads-physical reads direct-physical reads direct (lob)) / session logical reads)

执行:

select 1-((a.value-b.value-c.value)/d.value)

  from v$sysstat a,v$sysstat b,v$sysstat c,v$sysstat d

  where a.name='physical reads' and

         b.name='physical reads direct' and

         c.name='physical reads direct (lob)' and

         d.name='session logical reads';

 

l  Soft parse ratio:这项将显示系统是否有太多硬解析。该值将会与原始统计数据对比以确保精确。例如,软解析率仅为0.2则表示硬解析率太高。不过,如果总解析量(parse count total)偏低,这项值可以被忽略。

公式:1 - ( parse count (hard) / parse count (total) )

执行:

select 1-(a.value/b.value)

  from v$sysstat a,v$sysstat b

  Where a.name='parse count (hard)' and b.name='parse count (total)';

 

l  In-memory sort ratio:该项显示内存中完成的排序所占比例。最理想状态下,在OLTP系统中,大部分排序不仅小并且能够完全在内存里完成排序。

公式:sorts (memory) / ( sorts (memory) + sorts (disk) )

执行:

select a.value/(b.value+c.value)

  from v$sysstat a,v$sysstat b,v$sysstat c

  where a.name='sorts (memory)' and

         b.name='sorts (memory)' and c.name='sorts (disk)';

 

l  Parse to execute ratio:在生产环境,最理想状态是一条sql语句一次解析多数运行。

公式:1 - (parse count/execute count)

执行:

select 1-(a.value/b.value)

  from v$sysstat a,v$sysstat b

  where a.name='parse count (total)' and b.name='execute count';

 

l  Parse CPU to total CPU ratio:该项显示总的CPU花费在执行及解析上的比率。如果这项比率较低,说明系统执行了太多的解析。

公式:1 - (parse time cpu / CPU used by this session)

执行:

select 1-(a.value/b.value)

  from v$sysstat a,v$sysstat b

  where a.name='parse time cpu' and

         b.name='CPU used by this session';

 

l  Parse time CPU to parse time elapsed:通常,该项显示锁竞争比率。这项比率计算

是否时间花费在解析分配给CPU进行周期运算(即生产工作)。解析时间花费不在CPU周期运算通常表示由于锁竞争导致了时间花费

公式:parse time cpu / parse time elapsed

执行:

select a.value/b.value

  from v$sysstat a,v$sysstat b

  where a.name='parse time cpu' and b.name='parse time elapsed';

 

V$SYSSTAT获取负载间档(Load Profile)数据

 

  负载间档是监控系统吞吐量和负载变化的重要部分,该部分提供如下每秒和每个事务的统计信息:logons cumulative, parse count (total), parse count (hard), executes, physical reads, physical writes, block changes, and redo size.

 

  被格式化的数据可检查'rates'是否过高,或用于对比其它基线数据设置为识别system profile在期间如何变化。例如,计算每个事务中block changes可用如下公式:

db block changes / ( user commits + user rollbacks )

执行:

select a.value/(b.value+c.value)

  from v$sysstat a,v$sysstat b,v$sysstat c

  where a.name='db block changes' and

         b.name='user commits' and c.name='user rollbacks';

 

 

其它计算统计以衡量负载方式,如下:

l  Blocks changed for each read:这项显示出block changesblock reads中的比例。它将指出是否系统主要用于只读访问或是主要进行诸多数据操作(如:inserts/updates/deletes)

公式:db block changes / session logical reads

执行:

select a.value/b.value

  from v$sysstat a,v$sysstat b

  where a.name='db block changes' and

         b.name='session logical reads' ;

分享到:
评论

相关推荐

    学些动态性能表-word版

    学习动态性能表(一)--v$sysstat 学习动态性能表(二)--v$sesstat 学习动态性能表(三)--v$sql&v$sql_plan 学习动态性能表(四)--v$sqltext&v$sqlarea 学习动态性能表(五)--v$session 学习动态性能表(六)--v$...

    oracle动态性能表

    学习动态性能表 第一篇--v$sysstat 2007.5.23  按照OracleDocument中的描述,v$sysstat存储自数据库实例运行那刻起就开始累计全实例(instance-wide)的资源使用情况。 类似于v$sesstat,该视图存储下列的统计信息...

    Oracle 动态性能表学习

    ### Oracle 动态性能表学习:深入理解 v$sysstat #### 一、v$sysstat 视图概述 在 Oracle 数据库管理中,动态性能视图(Dynamic Performance Views)是一组特殊的内置视图,提供了关于数据库实例及其内部组件的...

    oracle学习动态性能表

    其中,`v$sysstat`是Oracle DBA们最为关注的动态性能表之一,它记录了数据库实例自启动以来的各种资源使用情况。本文将基于提供的内容对`v$sysstat`进行详细解读,并探讨其在性能监控和调优中的应用。 #### v$...

    ORACLE動態性能表

    Oracle动态性能表,通常被称为V$视图,是Oracle数据库管理系统中的一个重要组成部分,它提供了对数据库运行时状态的实时信息。这些视图包含了丰富的数据库性能数据,对于DBA(数据库管理员)进行性能监控、问题诊断...

    sysstat-10.0.2

    "sysstat-10.0.2" 是一个在Linux环境下用于系统性能监控的重要工具包。这个工具包的版本号是10.0.2,它通常以tar.gz的压缩格式提供,便于用户下载和安装。sysstat是Linux系统管理员的得力助手,能够收集并分析系统的...

    学习 Oracle 动态性能表

    总结来说,Oracle动态性能表是性能分析和调优的关键工具,通过对v$sysstat等视图的深入理解和有效利用,DBA可以更好地理解系统行为,定位性能瓶颈,并采取相应措施提升数据库的性能和效率。无论是监控系统资源的使用...

    学习Oracle动态性能表

    1. **v$sysstat**:这是Oracle中的一个关键性能视图,包含了系统的统计信息,如执行的SQL语句数量、redo log写入量等。通过分析这些统计数据,可以发现系统的瓶颈,并进行相应的调优。 2. **v$sql&v$sql_plan**:v$...

    学习动态性能表_all_in_one

    Oracle数据库的动态性能表是DBA进行系统监控和性能调优的重要工具,其中`v$sysstat`是尤为关键的一个视图。这个视图记录了自数据库实例启动以来的全局实例级统计信息,涵盖了从事件发生次数、资源使用总量到执行时间...

    学习ORACLE动态性能表.doc

    Oracle数据库的动态性能表`v$sysstat`是数据库管理员进行性能分析和调优的重要工具。这个视图记录了从数据库实例启动以来的各种系统级别的统计信息,这些信息反映了数据库的运行状况,包括资源的使用、事件的发生...

    oracle动态性能视图详解

    通过深入学习和理解这些动态性能视图,数据库管理员和开发人员能够实时监控Oracle数据库的运行状态,及时发现性能问题,从而提高系统的整体性能和稳定性。在实际操作中,结合Oracle的其他工具,如SQL*Plus、企业管理...

    Oracle性能视图学习大全

    - **性能监控**:如`V$SYSSTAT`、`V$SESSION_EVENT`等,用于监控系统性能。 - **会话管理**:如`V$SESSION`、`V$LOCK`等,显示当前活跃会话的状态。 - **内存管理**:如`V$SGASTAT`、`V$PGAAGGREGATE_TARGET`等,...

    Oracle DBA学习笔记

    ### Oracle DBA 学习笔记知识点总结 #### 一、限制用户访问进程数量 在Oracle数据库管理中,可能会遇到因为连接池的问题导致某些用户的连接数超出预期,甚至达到数据库进程的最大值的情况。为了应对这种情况,可以...

    oracle数据字典关系图

    Oracle 数据库是业界广泛使用的关系型数据库管理系统之一,其内部管理了大量的元数据信息,这些元数据通常存储在系统表空间中的若干视图和表内,被称为数据字典。数据字典在Oracle数据库中扮演着非常重要的角色,它...

    数据库性能诊断的七种武器.ppt

    【诊断工具中的七种武器】是DBA进行性能诊断的核心工具,它们是Oracle的动态性能视图,包括V$SYSSTAT、V$SESSION、V$SESSTAT、V$SGASTAT等多个视图。这些视图提供了系统级、会话级以及资源使用等多方面的详细信息,...

    DBA面试题目

    - 利用`V$SYSSTAT`和`V$PGA`等视图来监控系统级统计数据。 - 分析AWR报告中的相关指标,如平均活动会话(AAS)等。 3. **Statspack的使用**: - Statspack是Oracle提供的性能监控工具包。 - 收集数据库性能数据,...

Global site tag (gtag.js) - Google Analytics