awr常用技巧

发布时间:2020-07-11 13:51:24 作者:春秋小记
来源:网络 阅读:249

awr保留10天,每小时收集一次:
begin DBMS_WORKLOAD_REPOSITORY.MODIFY_SNAPSHOT_SETTINGS(14400,60); end;
手动收集awr一次:
exec DBMS_WORKLOAD_REPOSITORY.CREATE_SNAPSHOT();

手动执行一个快照:
Exec dbms_workload_repository.create_snapshot; (这个要背出来哦,用的时候去翻手册,丢脸哦)

创建一个AWR基线

Exec DBMS_WORKLOAD_REPOSITORY.CREATE_BASELINE(start_snap_id,end_snap_id ,baseline_name);
@?/rdbms/admin/awrrpt 生成AWR报告
@?/rdbms/admin/awrddrpt AWR比对报告

@?/rdbms/admin/awrgrpt RAC 全局AWR

dbms_workload_repository手工管理AWR
1、修改快照设置

[sql] view plaincopyprint?
查看awr保留的天数和采集频率:
sys@ORCL> select * from dba_hist_wr_control;

      DBID SNAP_INTERVAL             RETENTION                      TOPNSQL  
---------- ------------------------- ------------------------------ ----------  
1301772781 +00000 01:00:00.0         +00008 00:00:00.0              DEFAULT  

修改awr保留的天数和采集频率:
sys@ORCL> exec dbms_workload_repository.modify_snapshot_settings(retention => 15*1440,interval => 30);

PL/SQL 过程已成功完成。  

sys@ORCL> select * from dba_hist_wr_control;  

      DBID SNAP_INTERVAL             RETENTION                      TOPNSQL  
---------- ------------------------- ------------------------------ ----------  
1301772781 +00000 00:30:00.0         +00015 00:00:00.0              DEFAULT  

interval:将间隔设置为0时,oracle将禁止采用自动和手工快照的机制。
retention:当保存时间设置为0时,oracle将永久地保存这个快照。

2、创建和删除快照

[sql] view plaincopyprint?
手动执行一个awr快照:
sys@ORCL> exec dbms_workload_repository.create_snapshot();

PL/SQL 过程已成功完成。  

删除awr报告(指定删除范围):
sys@ORCL> exec dbms_workload_repository.drop_snapshot_range(low_snap_id => 10,high_snap_id => 12);

PL/SQL 过程已成功完成。  

sys@ORCL> exec dbms_workload_repository.drop_snapshot_range(low_snap_id => 628,high_snap_id => 629);  

PL/SQL 过程已成功完成。  

dba_hist_snapshot视图将列出有关可用快照的信息。
SELECT * FROM dba_hist_snapshot

3、创建和删除基线

[sql] view plaincopyprint?

sys@ORCL> exec dbms_workload_repository.create_baseline(start_snap_id => 630,end_snap_id => 635,baseline_name => 'base line');  

PL/SQL 过程已成功完成。  

sys@ORCL> select baseline_name,start_snap_id,end_snap_id from dba_hist_baseline;  

BASELINE_NAME                                                    START_SNAP_ID END_SNAP_ID  
---------------------------------------------------------------- ------------- -----------  
base line                                                                  630         635  
SYSTEM_MOVING_WINDOW                                                       636         637  

sys@ORCL> exec dbms_workload_repository.drop_baseline(baseline_name => 'base line',cascade => true);  

PL/SQL 过程已成功完成。  

sys@ORCL> select baseline_name,start_snap_id,end_snap_id from dba_hist_baseline;  

BASELINE_NAME                                                    START_SNAP_ID END_SNAP_ID  
---------------------------------------------------------------- ------------- -----------  
SYSTEM_MOVING_WINDOW                                                       636         637  

sys@ORCL> exec dbms_workload_repository.create_baseline(to_date('2013-11-03 00:00:00','yyyy-mm-dd hh34:mi:ss'),to_date('2013-11-03 06:00:00','yyyy-mm-dd hh34:mi:ss'),'base line2');  

PL/SQL 过程已成功完成。  

sys@ORCL> select baseline_name,start_snap_id,end_snap_id from dba_hist_baseline;  

BASELINE_NAME                                                    START_SNAP_ID END_SNAP_ID  
---------------------------------------------------------------- ------------- -----------  
base line                                                                  685         686  
base line2                                                                 685         686  
SYSTEM_MOVING_WINDOW                                                       640         696  

4、自动创建AWR基线

[sql] view plaincopyprint?

sys@ORCL> alter session set NLS_DATE_FORMAT= 'yyyy-mm-dd hh34:mi:ss';  

会话已更改。  

sys@ORCL> exec DBMS_WORKLOAD_REPOSITORY.create_baseline_template( -  
>     day_of_week          => 'WEDNESDAY', -  
>     hour_in_day          => 0, -  
>     duration             => 6, -  
>     start_time           => '2013-11-01:00:00:00', -  
>     end_time             => '2013-12-31:06:00:00', -  
>     baseline_name_prefix => 'Batch Baseline ', -  
>     template_name        => 'Batch Template', -  
>     expiration           => 365);  

PL/SQL 过程已成功完成。  

sys@ORCL> select t.template_name,  
  2         t.template_type,  
  3         t.start_time,  
  4         t.end_time,  
  5         t.day_of_week,  
  6         t.hour_in_day,  
  7         t.duration  
  8    from dba_hist_baseline_template t;  

TEMPLATE_NAME                  TEMPLATE_ START_TIME          END_TIME            DAY_OF_WE HOUR_IN_DAY   DURATION  
------------------------------ --------- ------------------- ------------------- --------- ----------- ----------  
Batch Template                 REPEATING 2013-11-01 00:00:00 2013-12-31 06:00:00 WEDNESDAY           0          6  

sys@ORCL> exec DBMS_WORKLOAD_REPOSITORY.drop_baseline_template('Batch Template');  

PL/SQL 过程已成功完成。  

day_of_week:天或者星期,基线在这个时间上重复。Specify one of the following values:('SUNDAY', 'MONDAY', 'TUESDAY', 'WEDNESDAY','THURSDAY', 'FRIDAY', 'SATURDAY', 'ALL')
hour_in_day:0-23,执行基线在这个小时开始。
duration:持续时间(小时数)。
start_time:创建基线的开始时间。
end_time:创建基线的结束时间。
expiration :基线过期的天数。

对于上面这个模板,将会在每周三根据0:00到上午6:00的时间窗口创建固定基线。

推荐阅读:
  1. python常用小技巧
  2. AWR oracle

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

oracle awr

上一篇:python切片是不是属于浅拷贝

下一篇:中介者模式和命令模式

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》