OracleAWR删除历史快照说明
一。 AWR概述
之前整理过一篇AWR的说明的文档
Oracle AWR Automatic Workload Repository 说明http://blog.csdn.net/tianlesoftware/article/details/4682300
从Oracle 10g开始 Oracle推出一个工具 AWR Automatic WorkloadRepository 并建议用AWR代替9i的Statspack.
AWR实质上是一个Oracle的内置工具它采集与性能相关的统计数据并从那些统计数据中导出性能量度 以跟踪潜在的问题。
AWR的快照由一个MMON的后台进程及其从进程自动地每小时采集一次。为了节省空间在Oracle 10g中快照会保留7天 11g的快照保留8天超过的会自动删除快照频率和保留时间都可以由用户修改。
AWR使用几个表来存储采集的统计数据所有的表都存储在新的名称为SYSAUX的特定表空间中的SYS模式下并且以WRM$_*和WRH$_*的格式命名
1 WRM$_*类表存储元数据信息如检查的数据库和采集的快照
2 WRH$_*类保存实际采集的统计数据。
H代表"历史数据 historical "而M代表"元数据 metadata ".
在这些表上构建了几种带前缀DBA_HIST_的视图这些视图可以用来编写您自己的性能诊断工具。视图的名称直接与表相关例如视图
DBA_HIST_SYSMETRIC_SUMMARY是在WRH$_SYSMETRIC_SUMMARY表上构建的。
二。 AWR快照的删除
2. 1为什么要删除AWR快照
默认情况下对于数据库自身产生的AWR报告会保留7天或8天。
SQL> select dbid, retention fromdba_hist_wr_control;
DBID RETENTION
---------------------------------------------------------------------
879543530 +00008 00:00:00.0
这个是我11g的库显示为8天如果是Oracle 10g,则会保留7天。
AWR快照也可以从其他的数据库中导入我们这里看一下
SQL> select dbid, retention fromdba_hist_wr_control;
DBID RETENTION
----------
877621333 +40150 00:00:00.0
879543530 +00008 00:00:00.0
如果是从其他库导入的快照在10g以后会保存110年40150/365 这部分数据不会永久删除。
--AWR导出脚本
SQL> @?/rdbms/admin/awrextr. sql
--AWR导入脚本
SQL> @?/rdbms/admin/awrload. sql
另一个很重要的原因就是有时候自动快照不能自动收集而手工创建快照又可以成功对于这种问题的解决方法就是把之前的快照清空掉。
2.2删除AWR快照数据
2.2. 1使用dbms_workload_repository包来删除
2.2. 1. 1删除本机的AWR快照
SQL> select dbid, retention fromdba_hist_wr_control;
DBID RETENTION
---------- --------------------
879543530 +00008 00:00:00.0
SQL> selectminsnap_id maxsnap_id from dba_hist_snapshot wheredbid = 879543530;
MIN SNAP_ID MAX SNAP_ID
------------------------
161 176
SQL> execdbms_workload_repository.drop_snapshot_range 161, 176,
879543530
PL/SQL proceduresuccessfully completed.
SQL> select *from dba_hist_snapshot where dbid = 879543530;no rows selected
2.2. 1.2删除其他实例的快照
SQL> select dbid, retention fromdba_hist_wr_control;
DBID RETENTION
----------
---------------------------------------------------------------------
877621333 +40150 00:00:00.0
879543530 +00008 00:00:00.0
SQL> select minsnap_id maxsnap_idfrom dba_hist_snapshot wheredbid = 877621333;
MIN SNAP_ID MAX SNAP_ID
------------ ------------
160 192
SQL> execdbms_workload_repository.drop_snapshot_range 160, 170,
877621333
PL/SQL procedure successfully completed.
SQL> select min snap_id max snap_id from dba_hist_snapshotwhere dbid =877621333;
MIN SNAP_ID MAX SNAP_ID
------------ ------------
171 192
SQL>
删除成功。
2.2.2使用dbms_swrf_internal包来删除
2.2.2. 1删除其他数据库导入的AWR
SQL> select dbid, retention fromdba_hist_wr_control;
DBID RETENTION
---------------------------------------------------------------------
877621333 +40150 00:00:00.0
879543530 +00008 00:00:00.0
SQL> select minsnap_id maxsnap_idfrom dba_hist_snapshot wheredbid = 877621333;
MIN SNAP_ID MAX SNAP_ID
160 192
SQL> exec dbms_swrf_internal.unregister_database 877621333
PL/SQL procedure successfully completed.
SQL> select minsnap_id maxsnap_idfrom dba_hist_snapshot wheredbid = 877621333;
MIN SNAP_ID MAX SNAP_ID
------------ ------------
SQL> select dbid, retention fromdba_hist_wr_control;
DBID RETENTION
---------------------------------------------------------------------
----------
879543530 +00008 00:00:00.0
SQL>dbms_swrf_internal.unregister_database会把所有的快照直接干掉与我们上节中的删除是不同的效果。
2.2.2.2删除本机的AWR
我们之前把快照清空了所以没有结果
SQL> select * from dba_hist_snapshotwhere dbid = 879543530;no rows selected
SQL> executedbms_workload_repository.create_snapshot
PL/SQL procedure successfully completed.
SQL> executedbms_workload_repository.create_snapshot
PL/SQL procedure successfully completed.
SQL> executedbms_workload_repository.create_snapshot
PL/SQL procedure successfully completed.
SQL> executedbms_workload_repository.create_snapshot
PL/SQL procedure successfully completed.
--现在又有快照了
SQL> select minsnap_id maxsnap_idfrom dba_hist_snapshot wheredbid = 879543530;
MIN SNAP_ID MAX SNAP_ID
------------ ------------
177 180
--删除快照
SQL> exec dbms_swrf_internal.unregister_database 879543530
BEGINdbms_swrf_internal.unregister_database 879543530 END;
*
ERROR at line 1:
ORA-13521: Unregister operation on localDatabase id 879543530 notallowed
ORA-06512: at"SYS.DBMS_SWRF_INTERNAL", l ine 99
ORA-06512: at line 1
这里直接提示 dbms_swrf_internal.unregister_database不能对本地的数据库使用。所以如果本地的数据库就只能使用dbms_workload_repository包了。
2.2.3小结dbms_workload_repository:
可以删除本地和其他数据库的快照可以选择不同的快照来进行删除。dbms_swrf_internal:
只能对其他数据库的快照来进行操作会把整个快照unregister掉。 d
PS;本文档由北大青鸟广安门收集自互联网仅作分享之用。
vollcloud LLC首次推出6折促销,本次促销福利主要感恩与回馈广大用户对于我们的信任与支持,我们将继续稳步前行,为广大用户们提供更好的产品和服务,另外,本次促销码共限制使用30个,个人不限购,用完活动结束,同时所有vps产品支持3日内无条件退款和提供免费试用。需要了解更多产品可前往官网查看!vollcloud优惠码:VoLLcloud终生6折促销码:Y5C0V7R0YW商品名称CPU内存S...
官方网站:https://www.akkocloud.com/AkkoCloud新品英国伦敦CN2 GIA已上线三网回程CN2 GIA 国内速度优秀.电信去程CN2 GIALooking Glass:http://lonlg.akkocloud.com/Speedtest:http://lonlg.akkocloud.com/speedtest/新品上线刚好碰上国庆节 特此放上国庆专属九折循环优惠...
A2Hosting主机,A2Hosting怎么样?A2Hosting是UK2集团下属公司,成立于2003年的老牌国外主机商,产品包括虚拟主机、VPS和独立服务器等,数据中心提供包括美国、新加坡softlayer和荷兰三个地区机房。A2Hosting在国外是一家非常大非常有名气的终合型主机商,拥有几百万的客户,非常值得信赖,国外主机论坛对它家的虚拟主机评价非常不错,当前,A2Hosting主机庆祝1...