测试时,发现无法产生新快照,查看系统时间为10月26,但是已经产生快照为12月1号了。

此时的解决办法,就是删除现有的快照。

http://itlab.idcquan.com/Oracle/backup/947118_2.html

 一。 AWR 概述

  之前整理过一篇AWR 的说明的文档:

  Oracle AWR(Automatic Workload Repository) 说明

  http://blog.csdn.net/tianlesoftware/article/details/4682300

  从Oracle 10g 开始,Oracle 推出一个工具:AWR(Automatic Workload Repository),并建议用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 from dba_hist_wr_control;

  DBID RETENTION

  -------------------------------------------------------------------------------------

  879543530 +00008 00:00:00.0

  这个是我11g的库,显示为8天,如果是Oracle 10g,则会保留7天。

  AWR 快照也可以从其他的数据库中导入,我们这里看一下:

  SQL> select dbid, retention from dba_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 from dba_hist_wr_control;

  DBID RETENTION

  ---------- --------------------

  879543530 +00008 00:00:00.0

  SQL> select min(snap_id), max(snap_id) from dba_hist_snapshot where dbid = 879543530;

  MIN(SNAP_ID)MAX(SNAP_ID)

  ------------------------

  161 176

  SQL> exec dbms_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 min(snap_id), max(snap_id)from dba_hist_snapshot where dbid = 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_snapshot where 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 min(snap_id), max(snap_id)from dba_hist_snapshot where dbid = 877621333;

  MIN(SNAP_ID) MAX(SNAP_ID)

------------ ------------

  160 192

  SQL> exec dbms_swrf_internal.unregister_database(877621333)

  PL/SQL procedure successfully completed.

  SQL> select min(snap_id), max(snap_id)from dba_hist_snapshot where dbid = 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 min(snap_id), max(snap_id)from dba_hist_snapshot where dbid = 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) not allowed

  ORA-06512: at"SYS.DBMS_SWRF_INTERNAL", line 99

  ORA-06512: at line 1

  这里直接提示,dbms_swrf_internal.unregister_database不能对本地的数据库使用。所以如果本地的数据库,就只能使用dbms_workload_repository包了。

  2.2.3 小结

  dbms_workload_repository:

  可以删除本地和其他数据库的快照,可以选择不同的快照来进行删除。

  dbms_swrf_internal:

  只能对其他数据库的快照来进行操作,会把整个快照unregister掉。

OracleAWR删除历史快照说明的更多相关文章

  1. git 仓库中删除历史大文件

    git 仓库中删除历史大文件 在git中增加了一个很大的文件,而且被保存在历史提交记录中,每次拉取代码都很大,速度很慢.而且用删除 提交历史记录的方式不是很实际. 以下分几个步骤介绍如何减小.git文 ...

  2. Hive批量删除历史分区

    批量删除历史分区和数据可以采用如下操作: -- 删除20180101之前的所有分区 alter table example_table_name drop if exists partition (d ...

  3. 删除历史日志的一个API

    删除历史日志的一个API bool DeleteOldFiles(const char* strFolder, const char* strPrefix, bool is_recursion, UI ...

  4. Windows forfiles(删除历史文件)

    200 ? "200px" : this.width)!important;} --> 介绍 forfiles是windows自带的一个批量删除命令,对于时间的判断是通过文件 ...

  5. Vertica删除历史分区数据

    假设test用户下创建的t_jingyu表 vsql -Utest -wtestpwd create table t_jingyu( col1 int, col2 varchar, col3 time ...

  6. Jenkins 批量删除历史构建

    在一次巡查 Jenkins 时,发现很多个项目的历史构建比较多,这些历史构建对于现在来说又没有什么用处,那么想把它删除,但是一个一个删除很累,毕竟总共加起来有上千个,历史构建,而且还不只是一个项目.那 ...

  7. linux删除历史操作命令

    有时候在系统中做了任何操作,但不想被别人知道,毕竟系统别人都可以登入查看,那怎么把自己操作系统的历史命令删除而不让别人知晓呢? 在linux系统里一旦操作了任何命令,都会被记录下来,可以通过histo ...

  8. Git彻底删除历史提交记录的方法

    有时候我们可能会遇到git提交错误的情况,比如提交了敏感的信息或者提交了错误的版本.这个时候我们想将提交到代码库的记录删除,我们要怎么做呢? 首先,我们需要找到我们需要回滚到的提交点的hash,可以使 ...

  9. VM删除快照失败,磁盘空间不足,只是删除了快照名字(全网唯一解决办法)

    原创: 删除之前的快照,发现只是把名字删除了, 看着这么多文件也不知道怎么删,一顿百度google也是没找到答案 于是就自己琢磨 因为删除快照的时候,是先把快照删除,然后删除无效的文件 所以先让这个盘 ...

随机推荐

  1. 20165101刘天野 2018-2019-2《网络对抗技术》Exp3 免杀原理与实践

    20165101刘天野 2018-2019-2<网络对抗技术>Exp3 免杀原理与实践 1. 实践内容 1.1 正确使用msf编码器,msfvenom生成如jar之类的其他文件,veil- ...

  2. linux驱动调试--修改系统时钟终端来定位僵死问题【转】

    本文转载自:http://blog.chinaunix.net/uid-20671208-id-4940381.html 原文地址:linux驱动调试--修改系统时钟终端来定位僵死问题 作者:枫露清愁 ...

  3. Spring注解(生命周期)

    对于上面的知识图解,需要一点一点的研究. 首先核心容器: 控制反转 和 依赖注入 创建工程: maven仓库搜索 spring context  : 引入后 <!-- https://mvnre ...

  4. UVA 10288 Coupons (概率)

    题意:有n种纸片无限张,随机抽取,问平均情况下抽多少张可以保证抽中所有类型的纸片 题解:假设自己手上有k张,抽中已经抽过的概率为 s=k/n:那抽中下一张没被抽过的纸片概率为 (再抽一张中,两张中,三 ...

  5. Mac OS X 下部分Android手机无法连接adb问题之解决方案

    [原文]  时至当今,Android山寨手机厂商已如此之多,能修改和个性化定制Android OS的能人已是多如牛毛,有的牛人修改Android系统只会影响所修改的点,不会影响其它,然后还有的就不多说 ...

  6. NumPy统计函数

    NumPy - 统计函数 NumPy 有很多有用的统计函数,用于从数组中给定的元素中查找最小,最大,百分标准差和方差等. 函数说明如下: numpy.amin() 和 numpy.amax() 这些函 ...

  7. xp_sp3_pro_简中_x86_cd_vl_x14-74070

    1.镜像文件: zh-hans_windows_xp_professional_with_service_pack_3_x86_cd_vl_x14-74070.iso 来自 msdn itellyou ...

  8. js进阶---12-11、jquery如何给动态创建出来的元素绑定事件

    js进阶---12-11.jquery如何给动态创建出来的元素绑定事件 一.总结 一句话总结:通过事件委托的方式,通过on方法 1.on方法在事件绑定的时候,data方式带额外参数时,字符串参数和其它 ...

  9. 框架布局FrameLayout

    框架布局FrameLayout 一.简介 二.代码实例 结果图: 代码: 需要注意的代码: imageView_play.setVisibility(View.INVISIBLE); <Fram ...

  10. spring3: Aspectj后置返回通知

    Aspectj后置返回通知 接口: package chapter1.server; public interface IHelloService2 { public int sayAfterRetu ...