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;本文档由北大青鸟广安门收集自互联网仅作分享之用。
今天上午有网友在群里聊到是不是有新注册域名的海外域名商家的优惠活动。如果我们并非一定要在国外注册域名的话,最近年中促销期间,国内的服务商优惠力度还是比较大的,以前我们可能较多选择海外域名商家注册域名在于海外商家便宜,如今这几年国内的商家价格也不贵的。比如在前一段时间有分享到几个商家的年中活动:1、DNSPOD域名欢购活动 - 提供域名抢购活动、DNS解析折扣、SSL证书活动2、难得再次关注新网商家...
tmhhost可谓是相当熟悉国内网络情况(资质方面:ISP\ICP\工商齐备),专业售卖海外高端优质线路的云服务器和独立服务器,包括了:香港的三网cn2 gia、日本 cn2、日本软银云服务器、韩国CN2、美国三网cn2 gia 云服务器、美国 cn2 gia +200G高防的。另外还有国内云服务器:镇江BGP 大连BGP数据盘和系统盘分开,自带windows系统,支持支付宝付款和微信,简直就是专...
近日Friendhosting发布了最新的消息,新上线了美国迈阿密的云产品,之前的夏季优惠活动还在进行中,全场一次性45折优惠,最高可购买半年,超过半年优惠力度就不高了,Friendhosting商家的优势就是100Mbps带宽不限流量,有需要的朋友可以尝试一下。Friendhosting怎么样?Friendhosting服务器好不好?Friendhosting服务器值不值得购买?Friendho...