statspack使用

0.介绍与术语

为了更好的调优,建立一个基线用于后续系统出问题时的对比时很重要的,没有基线数据,对于定位一个问题是什么导致的是很困难的:系统的事务量是否增加了?事务或应用是否改变了?用户数是否增加了?

statspacke与utlbstat/utlestat调优脚本不同,它收集更多的数据,并且收集的数据会被永久的存储在数据库表中,用于后续的报告或分析。收集的数据可以被用来分析实例的健康和概要,高资源消耗sql,也有传统的等待事件和初始化参数。

statspace比 utlbstat/utlestat在下面几个方面有提高:
  - Statspack collects more data, including high resource SQL
    (and the optimizer execution plans for those statements)
-statspack收集更多的数据,包括高消耗的sql(及执行计划)

-statspacek在调优的时候,提前计算很多有用的比率,如cache hit比率等

-被perfstat用户拥有的表来存储这些数据而不是每次都创建删除表。数据放到表中让历史数据对比更加的简单。

-statspack分离收集的数据和产生的报告,数据被快照获取,在生成报告的时候可以被查询。

-通过使用dbmss_job或操作系统工具,数据收集更加的简单。

statspack是怎么工作的?

statspack是sql,pl/sql和sql*plus脚本的集合,可以用来收集,存储,查看性能数据,perfstat在安装的时候被自动创建,他拥有所有的对象,该用户被授予在表v$views上的query-only权限。

snap_id由数据库标识符,实例号组成唯一值,一旦快照被收集,运行性能报告时可能的。报告需要2个快照。

在9i中,em使用statspack数据并以图形化方式展现,到了10g,em开始使用awr,在10g中awr数据在内部采集并存储。

awr与statspack

awr是oracle server的组成部分,自动60分钟收集一次server相关的数据,当statistics_level被设置成typical或all时,server自己收集数据,addm使用这些数据来诊断问题,dba和性能优化工程师可以使用em来查看性能建议,或是使用awr。作为对比,statspace是手工来安装并配置的。


2.  statspack 配置
2.1.  数据库空间要求

对数据库空间的要求更加快照生成的频率来定。

statspack的表默认额初始extent,next extent是100k,1m,3m,或5m。为了安装statspack,最小空间要求是100MB,
.
2.2.  安装工具
安装脚本创建一个用户叫perfstat,拥有所有创建的对象。在安装期间会提示你输入perfstat的密码和默认表空间。
oracle建议使用sysaux表空间来作为perfstat的默认表空间。statspack用户的临时表空间会是数据库的默认临时表空间。
在安装期间,dbms_shared_pool包会被创建,dbms_shared_pool被用来pinstatspack的包在共享池中。
使用sysdba权限连接到数据库中,运行spcreate
    e.g.  Start SQL*Plus, then:
      on Unix:
        SQL>  connect / as sysdba
        SQL>  @?/rdbms/admin/spcreate
      on Windows:
        SQL>  connect / as sysdba
        SQL>  @%ORACLE_HOME%\rdbms\admin\spcreate
spcreate自动运行3个别的脚本
      1.  spcusr  ->  creates the user and grants privileges
      2.  spctab  ->  creates the tables
      3.  spcpkg  ->  creates the package
检查在安装时生成的3个文件spcusr.lis,spctab.lis,spcpkg.lis确保其中没有错误。
有2中方式安装statspack,一个是上面的那种方法,另外的一个就是批量的方法,可以不提示输入用户面膜,默认表空间及临时表空间。

批量方式安装

使用批量方式安装必须在sql*plus中指定密码和默认表空间,临时表空间的变量。

    变量是:
        perfstat_password    -> for the password
        default_tablespace   -> for the default tablespace
        temporary_tablespace -> for the temporary tablespace
 比如:
        on Unix:
          SQL>  connect / as sysdba
          SQL>  define default_tablespace='tools'
          SQL>  define temporary_tablespace='temp'
          SQL>  define perfstat_password='erg8oiw'
          SQL>  @?/rdbms/admin/spcreate
          SQL>  undefine perfstat_password
spcreate将不会再提示上面的信息。


2.3. 在安装过程中的错误
一个可能的错误就是使用了system表空间来作为perfstat的默认表空间。
在接受到错误后,为了更正错误,首先运行de-instll脚本,然后在运行install脚本。这两个脚本都必须在sql*plus中运行。
比如.  Start SQL*Plus, connect as a user with SYSDBA privilege, then:
       SQL> @spdrop
       SQL> @spcreate
3.  通过快照采集数据

最简单的交互方式产生快照是使用perfstat用户登录sql*plus,执行statspack.snap

比如:
      SQL>  connect perfstat/perfstat_password
      SQL>  execute statspack.snap;
为了更好的进行性能分析,设置timed_statistics成true,这样的话statspack的数据就会包含重要的时间信息。
默认的数据收集级别是5,通过改变快照的级别是可以改变收集数据量的。
在你想自动收集生成报告的阶段,你要知道采集时候的snap_id,为了获取snap_id,使用statspack.snap函数,下面是一个例子。
   e.g. 
     SQL> variable snap number;
     SQL> begin   :snap := statspack.snap;   end;
       2  /
     PL/SQL procedure successfully completed.
     SQL> print snap
           SNAP
     ----------
             12

3.1.  自动化数据收集

为了一天,一星期或一年的数据,必须要生成很多的快照。最好的方法是隔一个时间段,自动的收集信息。

使用dbms_job存储过程来调度快照。

    - using Operating System utilities.  On Unix systems, you could use 
      utilities such as 'cron' or 'at'.  On Windows, you could schedule a 
      task (e.g. via Start> Programs> Accessories> System Tools> 
      Scheduled Tasks).
3.2.  使用dbms_job

spauto.sql中提供了如何自动收集的方法。你也许想要在每天的常规时刻收集来反映系统oltp和批量的负载,比如9点,10点,11点,12点,下午6点为oltp负载收集,午夜12点到第二天6点收集批量任务的负载。

为了让dbms_job来调度快照自动运行,job_queue_processes初始化参数必须设置大于0.要是在集群中使用spauto.sql,对每个实例都要运行一次spauto.sql,相应的job_queue_processes参数在每个实例上都要设置。
 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

修改收集数据的间隔

  e.g.
    execute dbms_job.interval(1,'SYSDATE+(1/48)');

上面的结果是每隔半小时收集一次 1440/48=30
让job马上执行

    execute dbms_job.run();
移除自动任务:
    execute dbms_job.remove();
4. 运行报告

快照被收集了,就可以来生成报告了。可以生成2中报告1是实例的报告,2是sql的报告。

实例的报告时关于实例的各个方面的。实例的报告(spreport.sql和sprepins.sql)

spreport.sql调用sprepins.sql
sql报告是具体sql的报告,提供了详细的信息,需要改sql的hash value
在实例重启后的快照与重启之前的快照是不同同时使用的。
4.1. 运行报告
要生成报告,需要运行spreport.sql这个脚本。
 在运行spreport的时候,提示你输入下面的信息:
   1. The beginning snapshot Id
    2. The ending    snapshot Id
    3. The name of the report text file to be created
    e.g. on Unix
      SQL>  connect perfstat/perfstat_password
      SQL>  @?/rdbms/admin/spreport
    e.g. on Windows
      SQL>  connect perfstat/perfstat_password
      SQL>  @%ORACLE_HOME%\rdbms\admin\spreport
    Example output:
    SQL>  connect perfstat/perfstat_password
    Connected.
    SQL>  @spreport
 
Current Instance
~~~~~~~~~~~~~~~~

   DB Id    DB Name      Inst Num Instance
----------- ------------ -------- ------------
 2618106428 PRD1                1 prd1

Instances in this Statspack schema
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

   DB Id    Inst Num DB Name      Instance     Host
----------- -------- ------------ ------------ ------------
 2618106428        1 PRD10        prd1         dlsun525

Using  261810642 for database Id
Using          1 for instance number

Specify the number of days of snapshots to choose from
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Entering the number of days (n) will result in the most recent
(n) days of snapshots being listed.  Pressing without
specifying a number lists all completed snapshots.

Listing all Completed Snapshots

                           Snap                    Snap
Instance     DB Name         Id   Snap Started    Level Comment
------------ ------------ ----- ----------------- ----- ----------------------
prd1         PRD1             1 11 May 2000 12:07     5
                              2 11 May 2000 12:08     5


                              3 12 May 2000 07:07     5
                              4 12 May 2000 08:08     5

Specify the Begin and End Snapshot Ids
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Enter value for begin_snap: 1
Begin Snapshot Id specified: 1

Enter value for end_snap: 2

End   Snapshot Id specified: 2


Specify the Report Name
~~~~~~~~~~~~~~~~~~~~~~~
The default report file name is sp_1_2  To use this name,
press to continue, otherwise enter an alternative.
Enter value for report_name:

Using the report name sp_1_2

  The report will now scroll past, and also be written to the file
  specified (e.g. sp_1_2.lis).

批量模式报表生成

为了不需要提示的情况下生成报表,在sql*plus中指定下面的变量

      The variables are:
        begin_snap   -> specifies the begin Snapshot Id
        end_snap     -> specifies the end   Snapshot Id
        report_name  -> specifies the Report output name
      e.g.
        on Unix:
          SQL>  connect perfstat/perfstat_password
          SQL>  define begin_snap=1
          SQL>  define end_snap=2
          SQL>  define report_name=batch_run
          SQL>  @?/rdbms/admin/spreport
      spreport will no longer prompt for the above information.

4.2. 当有多个实例的时候生成报告,在rac下对特定的实例生成报告,需要运行sprepins.sql,会出现下面的提示
    1. The DBId
    2. The Instance Number
    3. The beginning snapshot Id
    4. The ending    snapshot Id

    5. The name of the report text file to be created

    Example output:
    SQL>  connect perfstat/perfstat_password
    Connected.
    SQL>  @sprepins

Instances in this Statspack schema
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~


   DB Id    Inst Num DB Name      Instance     Host
----------- -------- ------------ ------------ ------------
  590400074        1 CON90        con90        dlsun525
 4290976145        1 MAIL         MAIL         mailhost

Enter value for dbid: 4290976145
Using 4290976145 for database Id
Enter value for inst_num: 1
....

批量生成的方式,要指定下面的几个变量:
      The variables are
        dbid         -> specifies the dbid
        inst_num     -> specifies the instance number
        begin_snap   -> specifies the begin Snapshot Id
        end_snap     -> specifies the end   Snapshot Id
        report_name  -> specifies the Report output name
      e.g.
          SQL>  connect perfstat/perfstat_password
          SQL>  define dbid=4290976145
          SQL>  define inst_num=1
          SQL>  define begin_snap=1
          SQL>  define end_snap=2
          SQL>  define report_name=batch_run
          SQL>  @?/rdbms/admin/sprepins

4.3配置实例报告

对于大多数情况,需要修改的变量只是num_days。备份sprepins.sql,在修改完后马上备份,免得再数据库升级完后,你还要重做这些修改。

num_days是要显示几天的快照,默认是显示全部快照,现在这个是可以配置的了。这个变量可以在实例报告和sql变量中修改。通过修改num_days来实现。 T
  e.g.
        define num_days = 60
这个变量有如下的有效值:
         - When a null string is used, all snapshots will be displayed.
                  This is the default setting.
                  e.g.  
                        define num_days = ''

            - Where n is the number of days of snapshots to list.
                  e.g. to set the number of days of snapshots to list to 31,
                  set num_days to 31:
                        define num_days = 31
    0           - A value of 0 means do not print out any snapshots.
                  This value would be of most use for batch execution of
                  the instance report, where the values for begin snap id and
                  end snap id are already known, thus printing out a list to
                  choose from is unneeded.
                  e.g.
                        define num_days = 0
    - This means the parameter is commented out in (or totally 
                  removed from) the file sprepins.sql
                  An undefined value for num_days will result in the report
                  prompting you for the number of days to enter, interactively.
                  Using '--' before the 'define' comments out the definition
                  of the variable, thus leaving it undefined.
                  e.g.
                       -- define num_days=31
                  Choosing this setting as your site's default means the 
                  instance report cannot be run in batch mode.

如果num_days不是设置的undefined,那么就不用输入值,要是设置的undefined,就要你输入提示的值,如下面的:

Current Instance
~~~~~~~~~~~~~~~~

   DB Id    DB Name      Inst Num Instance
----------- ------------ -------- ------------
 1296193444 MAINDB              1 maindb


Instances in this Statspack schema
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

   DB Id    Inst Num DB Name      Instance     Host
----------- -------- ------------ ------------ ------------
 1296193444        1 MAINDB       maindb       main1


Using 1296193444 for database Id
Using          1 for instance number


Specify the number of days of snapshots to choose from
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Entering the number of days (n) will result in the most recent
(n) days of snapshots being listed.  Pressing without
specifying a number lists all completed snapshots.


Enter value for num_days: 5


Listing the last 5 days of Completed Snapshots


                           Snap                    Snap
Instance     DB Name         Id   Snap Started    Level Comment
------------ ------------ ----- ----------------- ----- ----------------------
                             13 26 Sep 2002 17:01     5
                             14 27 Sep 2002 13:28     5
                             15 27 Sep 2002 13:29     5
                             16 30 Sep 2002 14:40     5


Specify the Begin and End Snapshot Ids
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Enter value for begin_snap: 
....

  SQL section report settings - top_n_sql

  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

在sql报告中要展现多少sql,默认是65,可以通过修改top_n_sql来修改这个值

  e.g.
        define top_n_sql = 65;
  SQL section report settings - num_rows_per_hash

  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

这个是控制在sql报告中sql文本显示的最大上限。默认值是4,也就是sql文本最多显示4行,要改变这个值,修改num_rows_per_hash

  e.g.
        define num_rows_per_hash = 10;
  SQL section report settings - top_pct_sql

  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

这个参数限制sql显示,只有超过top_pct_sql百分比资源使用的sql才会作为报告用的sql,默认是1%。

  This is a number which restricts the rows of SQL shown in the SQL sections  
  of the report.  Only SQL statements which exceeded top_pct_sql percentage
  of resources used, are candidates for listing in the report.
  The default value is 1.0%  To change the default, change the value of the
  variable top_pct_sql.
  e.g. 
        define top_pct_sql = 0.5;
在sql报告的ordered by gets部分,sql只有超过0.5%的sql才能在报告中显示。
  Segment related report settings - top_n_segstat

  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

段相关的设置 top_n_segstat,默认值是5,top 5的逻辑读sql被展示,按下面的修改设置:

  The number of top segments to display in each of the Segment sections of 
  the instance report.
  The default value is 5, which means only the top 5 segments in each category
  (e.g. top 5 logical reads) will be displayed.  To change the default, 
  change the value of the variable top_n_segstat.
  e.g. 
         define top_n_segstat = 5;
4.4. Running the SQL report
运行sql报告
  sprepsql.sql展示了sql的信息,快照在第6级别收集,sql的相关执行计划也会显示。要在集群环境中运行sprepsql.sql,必须要连接到相应的实例上。
你呀输入:
    1. The beginning snapshot Id
    2. The ending    snapshot Id
    3. The Hash Value for the SQL statement
    4. The name of the report text file to be created

    Example output:
    SQL>  connect perfstat/perfstat_password
    Connected.
    SQL>  @sprepsql


   DB Id    DB Name      Inst Num Instance
----------- ------------ -------- ------------
 2618106428 PRD1                1 prd1


Completed Snapshots
                           Snap                    Snap
Instance     DB Name         Id   Snap Started    Level Comment
------------ ------------ ----- ----------------- ----- ----------------------
prd1         PRD1            37 02 Mar 2001 11:01     6
                             38 02 Mar 2001 12:01     6


                             39 08 Mar 2001 09:01     5
                             40 08 Mar 2001 10:02     5


Specify the Begin and End Snapshot Ids
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Enter value for begin_snap: 39
Begin Snapshot Id specified: 39


Enter value for end_snap: 40
End   Snapshot Id specified: 40


Specify the Hash Value
~~~~~~~~~~~~~~~~~~~~~~
Enter value for hash_value: 1988538571
Hash Value specified is: 1988538571


Specify the Report Name
~~~~~~~~~~~~~~~~~~~~~~~
The default report file name is sp_39_40_1988538571.  To use this name,
press to continue, otherwise enter an alternative.
Enter value for report_name: 


Using the report name sp_39_40_1988538571
....


  The report will scroll past, and also be written to the file
  specified (e.g. sp_39_40_1988538571.lis).
批量报告声称
      The variables are:
        begin_snap   -> specifies the begin Snapshot Id
        end_snap     -> specifies the end   Snapshot Id
        hash_value   -> specifies the Hash Value
        report_name  -> specifies the Report output name

      e.g.
          SQL>  connect perfstat/perfstat_password
          SQL>  define begin_snap=39
          SQL>  define end_snap=40
          SQL>  define hash_value=1988538571
          SQL>  define report_name=batch_sql_run
          SQL>  @sprepsql
      sprepsql will no longer prompt for the above information.

4.5. 在多实例的库上运行sql报告
在rac中查看sql报告,要运行sprsqins.sql
   You will be prompted for:
    1. The DBId
    2. The Instance Number
    3. The beginning snapshot Id
    4. The ending    snapshot Id
    5. The Hash Value for the SQL statement
    6. The name of the report text file to be created

    Example output:
    SQL>  connect perfstat/perfstat_password
    Connected.
    SQL>  @sprsqins

Current Instance
~~~~~~~~~~~~~~~~


   DB Id    DB Name      Inst Num Instance
----------- ------------ -------- ------------
 1296193444 MAINDB              1 maindb


Instances in this Statspack schema
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~


   DB Id    Inst Num DB Name      Instance     Host
----------- -------- ------------ ------------ ------------
 1296193444        1 MAINDB       maindb       main1
 4290976145        1 MAIL         MAIL         mailhost


Enter value for dbid: 4290976145
Using 4290976145 for database Id
Enter value for inst_num: 1
....

批量报告生成

      ----------------------------
      The variables are:
        dbid         -> specifies the dbid
        inst_num     -> specifies the instance number
        begin_snap   -> specifies the begin Snapshot Id
        end_snap     -> specifies the end   Snapshot Id
        hash_value   -> specifies the Hash Value        
        report_name  -> specifies the Report output name
      e.g.
          SQL>  connect perfstat/perfstat_password
          SQL>  define dbid=4290976145
          SQL>  define inst_num=1
          SQL>  define begin_snap=1
          SQL>  define end_snap=2
          SQL>  define hash_value=1988538571
          SQL>  define report_name=batch_run
          SQL>  @?/rdbms/admin/sprsqins

4.7.在perfstat模式下收集优化器数据
为了更好的分析性能报告,优化器的数据做好在statspack模式中收集,当perfstat's表中的数据有较大变化的时候,使用dbms_stats来收集数据
execute dbms_stats.gather_schema_stats(ownname=>'PERFSTAT',cascade=>true);

5.  配置收集的数据量

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
快照的级别和阀值的都会限制收集的数据量。

5.1. 快照的级别
快照级别越高,收集的数据就越多,默认的级别是5.对典型的应用,级别是5就够用了,在设置基线的时候可以使用级别6.
5.2. 快照阀值
在设置快照级别的时候,也可以设置快照的阀值。快照的级别和阀值的信息存储在stats$statspack_parameter表中
5.3.修改快照级别和阀值

临时使用新值,临时修改,并不会保存,下面是临时修改到级别6

  e.g. Take a single level 6 snapshot (do not save level 6 as the default):
    SQL>  execute statspack.snap(i_snap_level=>6);

保存新值

按下面的步骤保存新值:
获取快照,并修改值。
     SQL>  execute statspack.snap - 
           (i_snap_level=>10, i_modify_parameter=>'true');
设置i_modiry_parameter参数成true会在stats$statspack_parameter表中保存新值,这些阀值会被后续的快照应用。
如果i_modify_parameter被设置成false或没有设置,新值不会被保存,只是在当时的快照中生效,后续的还是会使用stats$statspack_parameter表中的参数。

修改默认值不获取快照,使用statspack.modify_statspack_parameter存储过程,为了修改级别到10,设置buffer_gets和disk_reads值,使用下面的语句:

 SQL>  execute statspack.modify_statspack_parameter - 

            (i_snap_level=>10, i_buffer_gets_th=>10000, i_disk_reads_th=>1000);
这个存储过程永久修改值,但是不会生成快照。

5.4 快照级别-详细

0级别收集的数据:

这个级别或是高于0级别的收集基本的性能数据,比如:等待数据,系统事件,系统数据,回滚段数据,row cache ,sga,后台事件,会话事件,锁信息,bufferpool数据 ,latch数据,资源限制,队列数据,还有如下启用的信息:aum,buffer cache advisory ,pga内存管理,集群数据库数据。


级别5 收集除了低级别收集的信息,还有 sql的资源使用 ,这个生成快照的花费的时间跟shared_pool_size相关。共享池越大,sql越多,就越慢。

 sql阀值

sql超过下面的一个限制就会被收集,这些限制是预定义的:

1sql执行次数,默认是100

2sql执行的磁盘读取数,默认是1000

3sql解析调用数 ,默认是1000

4sql的buffer gets默认是1000

5sql使用的共享内存大小 ,默认是 1m

6sql的版本数量 默认是 20


快照级别6除了获取低级别的信息还 获取的额外信息,sql计划和sql计划的使用
为了获取sql计划,当快照执行的时候,sql一定要在共享池中 ,并且超过了阀值。为了获取在共享池中所有的sql信息,你可以临时指定阀值i_execution_th成0.

级别7 除了获取低级别的所有数据,还要获得段级别的信息。

 段级别的信息包含:

-逻辑读

-数据块改变

-物理读

-物理写

-物理直接读

-物理直接写


 下面是段数据的使用:

1相应物理读,物理写可以帮助你决定修改段的布局。

2高itl的等待可能暗示需要改变段的存储属性,像是pcrfree或initrans

3在rac中global cache对定位实例间的交通堵塞有帮助

 尽管statspack捕获所有的段信息,但是它只展示下面的信息:

1逻辑读

2物理读

3buffer busy waits

4itl waits

5row lock waits

6global cache cr blocks served*


 段阀值

        - number of logical reads on the segment                (default 10000)
        - number of physical reads on the segment               (default 1000)
        - number of buffer busy waits on the segment            (default 100)
        - number of row lock waits on the segment               (default 100)
        - number of ITL waits on the segment                    (default 100)
        - number of global cache Consistent Read blocks served* (default 1000)
        - number of global cache CUrrent blocks served*         (default 1000)

级别10除了收集低级别的信息,还收集 父子latch信息 ,这个是很耗时的,会导致资源紧张,需要在oracle建议下使用。
5.5. 指定session id

如果你想要获取sessin的数据和等待事件,可以指定sesion id 

    SQL>  execute statspack.snap(i_session_id=>3);
为了使session的数据在报告输出中显示,session的序列号一定要在快照的开始和结束时保持一致 ,如果不一致产生的报告就是无效的,会有下面的警告出来:
     WARNING: SESSION STATISTICS WILL NOT BE PRINTED, as session statistics
    captured in begin and end snapshots are for different sessions
    (Begin Snap sid,serial#: 10,752,  End Snap sid,serial#: 10,754).

5.6. 为snap和modify_statspack_parameters存储过程的输入参数

参数可以被传入statspack.snap和statspack.modiry_statspack_parameter存储过程中,参数如下面这些:
                    Range of      Default
Parameter Name      Valid Values  Value    Meaning
------------------  ------------  -------  -----------------------------------
i_snap_level        0,5,6,7,10    5        Snapshot Level
i_ucomment          Text            Comment to be stored with Snapshot
i_executions_th    Integer >=0   100      SQL Threshold: number of times
                                           the statement was executed
i_disk_reads_th    Integer >=0   1,000    SQL Threshold: number of disk reads 
                                           the statement made
i_parse_calls_th    Integer >=0   1,000    SQL Threshold: number of parse 
                                           calls the statement made
i_buffer_gets_th    Integer >=0   10,000   SQL Threshold: number of buffer
                                           gets the statement made
i_sharable_mem_th   Integer >=0   1048576  SQL Threshold: amount of sharable
                                           memory
i_version_count_th  Integer >=0   20       SQL Threshold: number of versions
                                           of a SQL statement
i_seg_phy_reads_th  Integer >=0   1,000    Segment statistic Threshold: number
                                           of physical reads on a segment. 
i_seg_log_reads_th  Integer >=0   1,0000   Segment statistic Threshold: number 
                                           of logical reads on a segment.
i_seg_buff_busy_th  Integer >=0   100      Segment statistic Threshold: number 
                                           of buffer busy waits for a segment.
i_seg_rowlock_w_th  Integer >=0   100      Segment statistic Threshold: number 
                                           of row lock waits for a segment.
i_seg_itl_waits_th  Integer >=0   100      Segment statistic Threshold: number 
                                           of ITL waits for a segment.
i_seg_cr_bks_sd_th  Integer >=0   1000     Segment statistic Threshold: number
                                           of Consistent Reads blocks served by
                                           the instance for the segment*.
i_seg_cu_bks_sd_th  Integer >=0   1000     Segment statistic Threshold: number
                                           of CUrrent blocks served by the
                                           instance for the segment*.
i_session_id        Valid sid     0 (no    Session Id of the Oracle Session
                    from          session) to capture session granular
                    v$session              statistics for
i_modify_parameter  True,False    False    Save the parameters specified for 
                                           future snapshots?

6性能数据的时间单元

oracle现在支持捕获秒及毫秒级别的性能数据 。如下视图包含秒

  - v$session_wait, v$system_event, v$session_event (time_waited_micro column)
  - v$sql, v$sqlarea (cpu_time, elapsed_time columns)
  - v$latch, v$latch_parent, v$latch_children (wait_time column)
  - v$sql_workarea, v$sql_workarea_active (active_time column)

包含毫秒的视图如下:

  - v$enqueue_stat (cum_wait_time)

For clarity, the time units used are specified in the column headings of
each timed column in the Statspack report.  The convention used is:
      (s)  - a second
      (cs) - a centisecond - which is       100th of a second
      (ms) - a millisecond - which is     1,000th of a second 
      (us) - a microsecond - which is 1,000,000th of a second 
7. 事件时间

如果计时可用,在报告中等待事件会按时间排序,如果timed_statistics是false,在后续用户的程序中设置了timed_statistics =true,那么在报告中看到时间和事件就 不正常了 。建议timed_statistics应该在实例级别设置成true用于诊断问题 。

8.性能数据的基线 

设置基线对于后续出问题时候来对比是很有必要的,设置成基线的快照不会被statspack丢弃。如果以后你不想保存之前的基线快照,你可以标记快照可以清除。新的存储过程和函数已经被添加到了 statspack包中 ,make_baseline和clear_baseline,他们都可以接受参数

-开始snap id 和结束snap id 

开始和结束snap id 对可以被指定,这种情况下,你或是选择开始snap id或 end snap id的范围作为baseline或是只是这两个snapshots作为基线,默认的是快照对之间的全部是基线。

-开始日期和结束日期
开始和结束日期可以被指定,所有在这个范围的快照都被标记为基线。
类似make_baseline存储过程,clear_baseline存储过程和方法接受相同的参数。

存储过程或函数

调用make_baseline存储过程或是 make_baseline函数都是可以的。唯一的不同时make_baseline函数返回设置成快照的号,而存储过程不会 。

相似的 clear_baseline返回清除的快照数量 。

  
  8.1.1.为make_baseLine和clear_baseline输入参数,输入开始快照id和结束快照id.

如果i_snap_rang参数设置了false那么只是输入的快照是 基线。

                    Range of           Default
Parameter Name      Valid Values       Value    Meaning
------------------  -----------------  -------  -------------------------------
i_begin_snap        Any Valid Snap Id  -        SnapId to start the baseline at
i_end_snap          Any valid Snap Id  -        SnapId to end the baseline at
i_snap_range        TRUE/FALSE         TRUE     Should the range of snapshots
                                                between the begin and end snap
                                                be included?
i_dbid              | Any valid DBId/  Current  Caters for RAC databases
i_instance_number   | inst number      DBId/    where you may wish to baseline
                      combination      Inst #   snapshots on one instance
                      in this                   which were physically taken
                      Statspack                 on another instance
                      schema

  Example 1:

为了使快照 45和50之间的快照成基线 ,并且不想有返回值看有多少快照被设置成基线 ,使用perfstat用户登录sql*plus

       SQL> exec statspack.make_baseline -
                 (i_begin_snap => 45, -
                  i_end_snap   => 50);
        或不指定参数名字
       SQL> exec statspack.make_baseline(45, 50);

  Example 2:

1237和1241范围中的都是基线 ,看返回至值,调用函数 。

       SQL> variable num_snaps number;
       SQL> begin
       SQL>   :num_snaps := statspack.make_baseline(1237, 1241);
       SQL> end;
       SQL> /
       SQL> print num_snaps

  Example 3:

只是设置1237与1241成基线

       SQL> exec statspack.make_baseline(5, 12, false);
clear_baseline也是按上面的例子使用的

  8.1.2为make_baseline和clear_baseline输入日期
 
                    Range of           Default
Parameter Name      Valid Values       Value    Meaning
------------------  -----------------  -------  -------------------------------
i_begin_date        Any valid date     -        Date to start the baseline at
i_end_date          Any valid date >   -        Date to end baseline at
                    begin date
i_dbid              | Any valid DBId/  Current  Caters for RAC databases
i_instance_number   | inst number      DBId/    where you may wish to baseline
                      combination      Inst #   snapshots on one instance
                      in this                   which were physically taken
                      Statspack                 on another instance
                      schema

  Example 1:
       To make a baseline of snapshots taken between 12-Feb-2003 at 9am, and 
       12-Feb-2003 at 12 midday (and be informed of the number of snapshots 
       affected), call the MAKE_BASELINE function.  Log into the PERFSTAT 
       user in SQL*Plus, and:

       SQL> variable num_snaps number;
       SQL> begin
       SQL>   :num_snaps := statspack.make_baseline 
                (to_date('12-FEB-2003 09:00','DD-MON-YYYY HH24:MI'),
                 to_date('12-FEB-2003 12:00','DD-MON-YYYY HH24:MI'));
       SQL> end;
       SQL> /
       SQL> print num_snaps
  Example 2:
       To clear an existing baseline which covers the times 13-Dec-2002 at 
       11pm and 14-Dec-2002 at 2am (without wanting to know how many 
       snapshots were affected), log into the PERFSTAT user in SQL*Plus, and:
       SQL> exec statspack.clear_baseline - 
              (to_date('13-DEC-2002 23:00','DD-MON-YYYY HH24:MI'), -
               to_date('14-FEB-2002 02:00','DD-MON-YYYY HH24:MI'));
8.2.清空删除不必要的数据 ,清空perfstat用户下面的不必要数据时可能的,但是基线快照不会被清空。
清空statspack 
-清空的数据可以使用snap id和end snap id指定 。
可以指定是清除之间所有的快照还是只是清除快照对。
  - 开始日期与结束日期
 - 清除指定日期之前的数据
- 几天内的数据

存储过程和函数


  8.2.1为purge存储过程和函数输入参数 
                    Range of           Default
Parameter Name      Valid Values       Value    Meaning
------------------  -----------------  -------  -------------------------------
i_begin_snap        Any Valid Snap Id  -        SnapId to start purging from
i_end_snap          Any valid Snap Id  -        SnapId to end purging at
i_snap_range        TRUE/FALSE         TRUE     Should the range of snapshots
                                                between the begin and end snap
                                                be included?
i_extended_purge    TRUE/FALSE         FALSE    Determines whether unused
                                                SQL Text, SQL Plans and 
                                                Segment Identifiers will be
                                                purged in addition to the
                                                normal data purged
i_dbid              | Any valid DBId/  Current  Caters for RAC databases
i_instance_number   | inst number      DBId/    where you may wish to baseline
                      combination      Inst #   snapshots on one instance
                      in this                   which were physically taken
                      Statspack                 on another instance
                      schema

  Example 1:
       Purge all snapshots between the specified begin and end snap ids.  Also
       purge unused SQL Text, SQL Plans and Segment Identifiers, and
       return the number of snapshots purged.  Log into the PERFSTAT user 
       in SQL*Plus, and:
       SQL> variable num_snaps number;
       SQL> begin
       SQL>   :num_snaps := statspack.purge
                 ( i_begin_snap=>1237, i_end_snap=>1241
                 , i_extended_purge=>TRUE);
       SQL> end;
       SQL> /
       SQL> print num_snaps       

  8.2.2.  为purge存储过程和函数输入日期。

                    Range of           Default
Parameter Name      Valid Values       Value    Meaning
------------------  -----------------  -------  -------------------------------
i_begin_date        Date               -        Date to start purging from
i_end_date          End date > begin   -        Date to end purging at
                    date               -        SnapId to end the baseline at
i_extended_purge    TRUE/FALSE         FALSE    Determines whether unused
                                                SQL Text, SQL Plans and 
                                                Segment Identifiers will be
                                                purged in addition to the
                                                normal data purged
i_dbid              | Any valid DBId/  Current  Caters for RAC databases
i_instance_number   | inst number      DBId/    where you may wish to baseline
                      combination      Inst #   snapshots on one instance
                      in this                   which were physically taken
                      Statspack                 on another instance
                      schema

  Example 1:
       Purge all snapshots which fall between 01-Jan-2003 and 02-Jan-2003.
       Also perform an extended purge.  Log into the PERFSTAT user in 
       SQL*Plus, and:
        SQL> exec statspack.purge -
               (i_begin_date=>to_date('01-JAN-2003', 'DD-MON-YYYY'), -
                i_end_date  =>to_date('02-JAN-2003', 'DD-MON-YYYY'), -
                i_extended_purge=>TRUE);

  8.2.3为purce存储过程或函数输入日期指定删除那个日期之前的数据

                    Range of           Default
Parameter Name      Valid Values       Value    Meaning
------------------  -----------------  -------  -------------------------------
i_purge_before_date Date               -        Snapshots older than this date
                                                will be purged
i_extended_purge    TRUE/FALSE         FALSE    Determines whether unused
                                                SQL Text, SQL Plans and 
                                                Segment Identifiers will be
                                                purged in addition to the
                                                normal data purged.
i_dbid              | Any valid DBId/  Current  Caters for RAC databases
i_instance_number   | inst number      DBId/    where you may wish to baseline
                      combination      Inst #   snapshots on one instance
                      in this                   which were physically taken
                      Statspack                 on another instance
                      schema
  Example 1:
       To purge data older than a specified date, without wanting to know the 
       number of snapshots purged, log into the PERFSTAT user in SQL*Plus,
       and:
       SQL> exec statspack.purge(to_date('31-OCT-2002','DD-MON-YYYY'));
  8.2.4. Input Parameters for the PURGE procedure and function
         which accept the Number of Days of data to keep
  This section describes the input parameters for the PURGE procedure and 
  function which accept the number of days of snapshots to keep.  All data
  older than the specified number of days will be purged.  The input 
  parameters for both procedure and function are identical.  If 
  i_extended_purge is TRUE, also perform an extended purge.
  If the function is called, it will return the number of snapshots purged.
                    Range of           Default
Parameter Name      Valid Values       Value    Meaning
------------------  -----------------  -------  -------------------------------
i_num_days          Number > 0         -        Snapshots older than this
                                                number of days will be purged
i_extended_purge    TRUE/FALSE         FALSE    Determines whether unused
                                                SQL Text, SQL Plans and 
                                                Segment Identifiers will be
                                                purged in addition to the
                                                normal data purged
i_dbid              | Any valid DBId/  Current  Caters for RAC databases
i_instance_number   | inst number      DBId/    where you may wish to baseline
                      combination      Inst #   snapshots on one instance
                      in this                   which were physically taken
                      Statspack                 on another instance
                      schema

  Example 1:
       To purge data older than 31 days, without wanting to know the number 
       of snapshots operated on, log into the PERFSTAT user in SQL*Plus, and:
       SQL> exec statspack.purge(31);

8.2.5使用sppurge.sql

当sppurge运行的时候,可用的快照被列出来,dba指定低snap id和高snap id,在这之间的所有快照都会被删除。这个删除动作时自动提交的,删除后就不能回滚了

  e.g. Purging data - connect to PERFSTAT using SQL*Plus, then run the
       sppurge.sql script - sample example output appears below.
SQL>  connect perfstat/perfstat_password
SQL>  set transaction use rollback segment rbig;
SQL>  @sppurge
Database Instance currently connected to
========================================
                                Instance
   DB Id    DB Name    Inst Num Name
----------- ---------- -------- ----------
  720559826 PERF              1 perf

Snapshots for this database instance
====================================
                               Base-  Snap
 Snap Id   Snapshot Started    line? Level Host            Comment
-------- --------------------- ----- ----- --------------- --------------------
       1  30 Feb 2000 10:00:01           6 perfhost
       2  30 Feb 2000 12:00:06 Y         6 perfhost
       3  01 Mar 2000 02:00:01 Y         6 perfhost
       4  01 Mar 2000 06:00:01           6 perfhost

Specify the Lo Snap Id and Hi Snap Id range to purge
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Enter value for losnapid: 1
Using 1 for lower bound.

Enter value for hisnapid: 2
Using 2 for upper bound.

Deleting snapshots 1 - 2

Purge of specified Snapshot range complete.

SQL> -- end of example output

8.3.删除所有的数据

如果想要清除所有的数据,可以使用sptrunc.sql,这个脚本会清除所有的数据,包括基线快照 。

    SQL>  connect perfstat/perfstat_password
    SQL>  @sptrunc
    Warning
    ~~~~~~~
    Running sptrunc.sql removes ALL data from Statspack tables.  You may
    wish to export the data before continuing.

    About to Truncate Statspack Tables
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    If would like to exit WITHOUT truncating the tables, enter any text at the
    begin_or_exit prompt (e.g. 'exit'), otherwise if you would like to begin
    the truncate operation, press

    Enter value for begin_or_exit: 
    Entered at the 'begin_or_exit' prompt

    ... Starting truncate operation

    Table truncated.
    Table truncated.
   
    Commit complete.
    Package altered.
    ... Truncate operation complete
8.4. 通过export共享数据 
一个导出参数spuexp.par已经提供了,可以使用这个参数到处数据。
例如:
    exp userid=perfstat/perfstat_password parfile=spuexp.par
这个将会创建一个spuexp.dmp和spuexp.log
 



你可能感兴趣的:(oracle管理)