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;本文档由北大青鸟广安门收集自互联网仅作分享之用。
百星数据(baixidc),2012年开始运作至今,主要提供境外自营云服务器和独立服务器出租业务,根据网络线路的不同划分为:美国cera 9929、美国cn2 gia、香港cn2 gia、韩国cn2 gia、日本cn2 gia等云服务器及物理服务器业务。目前,百星数据 推出的日本、韩国、香港cn2 gia云服务器,2核2G/40G/5M带宽低至60元/月,600元/年。百星数据优惠码:优惠码:30...
10gbiz发布了9月优惠方案,针对VPS、独立服务器、站群服务器、高防服务器等均提供了一系列优惠方面,其中香港/洛杉矶CN2 GIA线路VPS主机4折优惠继续,优惠后最低每月仅2.36美元起;日本/香港独立服务器提供特价款首月1.5折27.43美元起;站群/G口服务器首月半价,高防服务器永久8.5折等。这是一家成立于2020年的主机商,提供包括独立服务器租用和VPS主机等产品,数据中心包括美国洛...
BuyVM测评,BuyVM怎么样?BuyVM好不好?BuyVM,2010年成立的国外老牌稳定商家,Frantech Solutions旗下,主要提供基于KVM的VPS服务器,数据中心有拉斯维加斯、纽约、卢森堡,付费可选强大的DDOS防护(月付3美金),特色是1Gbps不限流量,稳定商家,而且卢森堡不限版权。1G或以上内存可以安装Windows 2012 64bit,无需任何费用,所有型号包括免费的...