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