当前位置:  数据库>oracle

RMAN 系列(七) ---- RMAN 维护

    来源: 互联网  发布时间:2017-04-10

    本文导语:  1. Rman 的维护 2. 恢复目录的维护 3. 备份恢复目录 4. RMAN 存储脚本 5. 删除数据库   在RMAN目录和物理备份目的地不同步的情况下,我们可以使用crosscheck命令来效验控制文件或恢复目录中的RMAN信息是否与备份介质上的实...

1. Rman 的维护

2. 恢复目录的维护

3. 备份恢复目录

4. RMAN 存储脚本

5. 删除数据库

 

在RMAN目录和物理备份目的地不同步的情况下,我们可以使用crosscheck命令来效验控制文件或恢复目录中的RMAN信息是否与备份介质上的实际物理备份集片相同。

使用crosscheck 命令时,我们关心每个备份集或者副本的状态。 如果使用控制文件,用于备份集片的v$backup_set 视图和用于副本的v$databfile_copy 视图中的status列列出了每个备份集或副本的状态码;如果使用恢复目录,则在备份集片的RC_BACKUP_SET和副本的RC_DATAFILE_COPY中列出了每个备份集或副本的状态码。 在不同的备份状态码中,我们关心以下

:RMAN 认定该项存在于备份介质上

:这个备份集片或副本上存储的RMAN目录(即控制文件或恢复目录)中,但是并没有物理存在于备份介质上。

 执行crosscheck时,RMAN检查目录中列出的每个备份集或副本并且判断他们是否存在与备份介质上。 如果备份集或副本不存在与备份介质上,它就会被标记为expired, 并且不能用于任何还原操作;如果备份集或副本存在与备份介质上,它就会维持available状态。

使用目标数据库控制文件替代恢复目录

分配的通道: ORA_DISK_1

通道 ORA_DISK_1: SID=25 设备类型=DISK

交叉校验备份片段: 找到为 'AVAILABLE'

备份片段句柄=F:/BACKUP/BL_01LI7BSC_1_1.BAK RECID=1 STAMP=723758988

交叉校验备份片段: 找到为 'AVAILABLE'

备份片段句柄=F:/BACKUP/BL_02LI7BSK_1_1.BAK RECID=2 STAMP=723758997

交叉校验备份片段: 找到为 'AVAILABLE'

备份片段句柄=F:/BACKUP/BL_03LI7BVK_1_1.BAK RECID=3 STAMP=723759093

。此外,可以通过识别与备份相关联的标记来选择要交叉效验和特定的备份。 基于使用的设备或者基于一个时间周期,我们甚至可以交叉效验所有的备份。 如:

Crosscheck backup of datafile 1;

Crosscheck backup of tablespace users;

Crosscheck backup of controlfile;

Crosscheck backup of spfile;

Crosscheck backup tag='TEST';

Crosscheck backup completed after 'sysdate-2';

Crosscheck backup completed between 'sysdate-5' and 'sysdate-2';

Crosscheck backup device type disk;

RMAN>

使用目标数据库控制文件替代恢复目录

分配的通道: ORA_DISK_1

通道 ORA_DISK_1: SID=24 设备类型=DISK

对归档日志的验证成功

归档日志文件名=D:/ARCHIVELOG/BL_ARC0000000005_0723658881.0001 RECID=1 STAMP=723756640

对归档日志的验证成功

归档日志文件名=D:/ARCHIVELOG/BL_ARC0000000006_0723658881.0001 RECID=2 STAMP=723758988

对归档日志的验证成功

归档日志文件名=D:/ARCHIVELOG/BL_ARC0000000007_0723658881.0001 RECID=3 STAMP=723759092

我们可以基于一个号码或标准(包括时间,具体的或指定范围的SCN或日志序列号)来交叉效验归档的重做日志备份,甚至还可以使用like参数与通配符来交叉效验特定的归档日志备份。 如:

Crosscheck archivelog like 'ARC001.log';

Crosscheck archivelog 'D:/archivelog/arc023.log';

Crosscheck archivelog like '%ARC00012.LOG';

Crosscheck archivelog from time "to_date('2010-7-10','yyyy-mm-dd')";

Crosscheck archivelog until time "to_date('2010-7-10','yyyy-mm-dd')";

Crosscheck archivelog from sequence 12;

Crosscheck archivelog until sequence 522;

 包括数据文件副本,控制文件副本,归档重做日志副本以及磁盘上的归档的重做日志。 如:

Crosscheck copy of datafile 5;

Crosscheck datafilecopy 'D:/APP/ADMINISTRATOR/ORADATA/BL/BL01.DBF';

 RMAN 提供的validate命令允许查看给定的备份集和进行验证以确保这个备份集能够被还原。注意,validate 命令必须要获得主键ID。 这个可以用list backup summary命令获取。

RMAN> list backup summary;

备份列表

===============

    TY LV S 设备类型 完成时间   段数 副本数 压缩标记

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

      B  A  A DISK        07-7月 -10 1       1       NO         TAG20100707T200948

       B  F  A DISK        07-7月 -10 1       1       NO         TAG20100707T200956

      B  A  A DISK        07-7月 -10 1       1       NO         TAG20100707T201132

RMAN> 

启动 validate 于 10-7月 -10

使用通道 ORA_DISK_1

通道 ORA_DISK_1: 正在开始验证归档日志备份集

通道 ORA_DISK_1: 正在读取备份片段 F:/BACKUP/BL_01LI7BSC_1_1.BAK

通道 ORA_DISK_1: 段句柄 = F:/BACKUP/BL_01LI7BSC_1_1.BAK 标记 = TAG20100707T200948

通道 ORA_DISK_1: 已还原备份片段 1

通道 ORA_DISK_1: 验证完成, 用时: 00:00:03

完成 validate 于 10-7月 -10

保存策略(retention policy)是管理备份和副本以及指定他们在备份介质上保存时间的一种方法。 我们可以定义两种基本的保存策略: (recovery window backup retention policy) 和 (backup redundancy backup retention policy)。

每个冗余策略将一直保持知道被修改或者删除(或者直到使用create controlfile命令重新构建控制文件的时候)。 两个冗余策略是相互排斥的。此外,即使使用了冗余策略

这种保存策略是基于想要数据库恢复到的最近日期定制的。 如:

Configure retention policy to recovery window 7 days;

在这个示例中,我们保存近7天的备份是有效的,超过7天的备份会被丢弃。

这种备份策略RMAN 会从最新备份开始保留n个数据库备份。 如:

Configure retention policy to redundancy 3;

这个示例中,我们保存最后3份有效的备份。

当一个给定的备份或者副本由于备份保存策略的标准而被丢弃时, 我们可以使用 report obsolete 命令查看被RMAN 标记为obsolete 的备份。

RMAN 保留策略将应用于该命令

将 RMAN 保留策略设置为冗余 1

类型                 关键字 完成时间           文件名/句柄

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

存档日志          1      07-7月 -10         D:/ARCHIVELOG/BL_ARC0000000005_0723658881.0001

存档日志          2      07-7月 -10         D:/ARCHIVELOG/BL_ARC0000000006_0723658881.0001

备份集               1      07-7月 -10

备份片段       1      07-7月 -10         F:/BACKUP/BL_01LI7BSC_1_1.BAK

当然,我。 使用这个命令时,其状态被修改的备份或副本被认为是一个长期备份(long-term backup),并且不受相应的保存策略的影响。

可以。此外,还。 我们还可以。示例:

RMAN> 

备份集列表

===================

  大小       设备类型占用时间 完成时间

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

      52.15M     DISK        00:00:04     07-7月 -10

        BP 关键字: 1   状态: AVAILABLE  已压缩: NO  标记: TAG20100707T200948

段名:F:/BACKUP/BL_01LI7BSC_1_1.BAK

  备份集 1 中的已存档日志列表

  线程序列     低 SCN    时间下限   下一个 SCN   下一次

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

  1    5       986340     06-7月 -10 1006590    07-7月 -10

  1    6       1006590    07-7月 -10 1008501    07-7月 -10

  类型 LV 大小       设备类型 经过时间 完成时间

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

     Full    974.46M    DISK        00:01:33     07-7月 -10

        BP 关键字: 2   状态: AVAILABLE  已压缩: NO  标记: TAG20100707T200956

段名:F:/BACKUP/BL_02LI7BSK_1_1.BAK

  备份集 2 中的��据文件列表

  文件 LV 类型 Ckp SCN    Ckp 时间   名称

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

  1       Full 1008510    07-7月 -10 D:/APP/ADMINISTRATOR/ORADATA/BL/SYSTEM01.DBF

  2       Full 1008510    07-7月 -10 D:/APP/ADMINISTRATOR/ORADATA/BL/SYSAUX01.DBF

  3       Full 1008510    07-7月 -10 D:/APP/ADMINISTRATOR/ORADATA/BL/UNDOTBS01.DBF

  4       Full 1008510    07-7月 -10 D:/APP/ADMINISTRATOR/ORADATA/BL/USERS01.DBF

  5       Full 1008510    07-7月 -10

修改一个备份或副本时,必须引用与这个备份关联的备份集关键字。 

另外,

(1)只有在使用恢复目录时,才可以使用该选项

(2)如果使用FRA,则不能使用该选项

修改备份为永久保存并将以及该备份的相关的日志保存下来,保证总能将备份恢复到当前时间点
    change backupset 31 keep forever logs;
设置备份丢弃的新日期,将备份在多保存7 天,7 天后将删除
    change backupset 32 keep until time 'sysdata + 7' logs;

检查完报告后,可以使用带有obsolete 参数的delete 命令指示Oracle 删除要丢弃的备份,如:

Delete obsolete;

如果要使一个备份不受所选冗余策略的影响,可以使用backup命令的keep 参数来为这个备份指定另一个保存标准。 如:

Backup database keep forever;

Backup database keep until time "to_date('2010-7-10','yyyy-mm-dd')";

Backup database keep 5 days;

Change 命令允许用户修改备份的状态。我们可能会遇到备份介质设备在某个时间爱你段中无效的情况(如突然断电)。这时,我们就可以使用change 命令来指示这个设备上的备份是不可用的。

解决硬件故障和修复磁盘后,额可以再次执行change 命令,将备份改为可用的状态。也可以将备份修改为不可用的状态。在还原和恢复操作期间,不会考虑哪些不可用的备份,但在执行delete expired命令期间这些备份记录不会被删除。 相关示例:

Change backup of database tag='TEST' unavailable;

Change backup of database like '%TEST%' unavailable;

Change backupset 33 unavailable;

Change backupset 33 available;

Change archivelog 'd:/archivelog/arc0001.log' unavailable;

如:将已经备份了指定次数的所有归档的重做日志备份修改为不可用的状态,也可以修改特定设备上的所有备份的状态。

Change archivelog all backed up 5 times to device type disk unavailable;

Change backup of database device type disk unavailable;

前提是要知道备份集关键字,可以使用list backup 或 list copy 命令查看。

RMAN> 

备份集列表

===================

  大小       设备类型占用时间 完成时间

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

      52.15M     DISK        00:00:04     07-7月 -10

        BP 关键字: 1   状态: AVAILABLE  已压缩: NO  标记: TAG20100707T200948

段名:F:/BACKUP/BL_01LI7BSC_1_1.BAK

  备份集 1 中的已存档日志列表

  线程序列     低 SCN    时间下限   下一个 SCN   下一次

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

  1    5       986340     06-7月 -10 1006590    07-7月 -10

  1    6       1006590    07-7月 -10 1008501    07-7月 -10

  类型 LV 大小       设备类型 经过时间 完成时间

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

       Full    974.46M    DISK        00:01:33     07-7月 -10

        BP 关键字: 2   状态: AVAILABLE  已压缩: NO  标记: TAG20100707T200956

段名:F:/BACKUP/BL_02LI7BSK_1_1.BAK

  备份集 2 中的数据文件列表

  文件 LV 类型 Ckp SCN    Ckp 时间   名称

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

  1       Full 1008510    07-7月 -10 D:/APP/ADMINISTRATOR/ORADATA/BL/SYSTEM01.DBF

  2       Full 1008510    07-7月 -10 D:/APP/ADMINISTRATOR/ORADATA/BL/SYSAUX01.DBF

  3       Full 1008510    07-7月 -10 D:/APP/ADMINISTRATOR/ORADATA/BL/UNDOTBS01.DBF

  4       Full 1008510    07-7月 -10 D:/APP/ADMINISTRATOR/ORADATA/BL/USERS01.DBF

  5       Full 1008510    07-7月 -10

RMAN> 

使用通道 ORA_DISK_1

备份片段列表

BP 关键字  BS 关键字  Pc# Cp# 状态      设备类型段名称

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

1       1       1   1   AVAILABLE   DISK        F:/BACKUP/BL_01LI7BSC_1_1.BAK

已删除

备份片段句柄=F:/BACKUP/BL_01LI7BSC_1_1.BAK RECID=1 STAMP=723758988

1 对象已删除

在上面的这个示例中,我们删除了备份集和它关联的备份片。 也可以。 通过 list backup命令我们可以看到备份片的名称,比如:段名:

我们也可以查看备份片的号码,用catalog 用户连接数据库后,查看rc_backup_piece 表,SQL如下:

SQL> select bs_key,bp_key,piece#,handle from rc_backup_piece;

            PIECE#   HANDLE

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

        52         55          1  D:/BACKUP/ORCL_02LI47UA_1_1

        53         56          1  D:/BACKUP/ORCL_03LI47UF_1_1

        75         82          1  D:/BACKUP/ORCL_04LI4816_1_1

RMAN> 

使用通道 ORA_DISK_1

备份片段列表

BP 关键字  BS 关键字  Pc# Cp# 状态      设备类型段名称

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

2       2       1   1   AVAILABLE   DISK        F:/BACKUP/BL_02LI7BSK_1_1.BAK

已删除备份片段

备份片段句柄=F:/BACKUP/BL_02LI7BSK_1_1.BAK RECID=2 STAMP=723758997

1 对象已删除

使用备份集片,如:

Change backuppiece 622 delete;

Change archivelog until logseq=54 delete;

最后,可以使用change backuppiece uncataog命令从目录中删除备份集片。 如果删除最后剩余的备份集片,那么它也将删除备份集记录。如:

Change backuppiece uncatalog;

备份集不是永远存在的。我们可以使用保存策略标记备份有效性和生存期的结束。但是,备份策略的实施不会从RMAN目录中删除备份,而只是将这些备份标记为丢弃状态。

Delete 命令对备份和副本的影响很大。通过delete命令,可以删除基于保存标准被标记为丢弃的任何备份,还可以将恢复目录或控制文件中的备份从expired状态变为deleted状态。 如:

Delete expired;

Delete obsolete;

执行delete命令时,RMAN会请求用户确认这个删除命令,如果确认了这个删除命令,RMAN 就会完成delete操作。

如果一个备份被标记为deleted 状态,就不能恢复这个备份。 如果该备份物理可用,我们仍然可以使用dbms_backup_restore过程来恢复这个备份。

使用catalog 命令可以在RMAN中记录数据文件备份,归档日志备份和控制文件备份,随后还能使用这些备份来还原和恢复数据库。 Oracle 10g允许使用catalog命令来为控制文件中已有的备份集片编写目录。当使用一个不包含最新的RMAN信息的较早备份控制文件还原数据库时,则可以很方便得使用该功能来完成。

示例:

我们先备份一个表空间,归档文件,控制文件。 然后通过catalog 把这些信息添加到恢复目录里。

SQL> 

已连接。

SQL>

表空间已更改。

SQL> 

FILE_NAME

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

D:/APP/ADMINISTRATOR/ORADATA/BL/USERS01.DBF

D:/APP/ADMINISTRATOR/ORADATA/BL/UNDOTBS01.DBF

D:/APP/ADMINISTRATOR/ORADATA/BL/SYSAUX01.DBF

D:/APP/ADMINISTRATOR/ORADATA/BL/SYSTEM01.DBF

D:/APP/ADMINISTRATOR/ORADATA/BL/BL01.DBF

SQL> 

已复制         1 个文件。

SQL>

表空间已更改。

SQL> 

系统已更改。

SQL> 

已复制         1 个文件。

SQL> 

数据库已更改。

C:/Users/Administrator.DavidDai>

恢复管理器: Release 11.2.0.1.0 - Production on 星期日 7月 11 08:51:50 2010

Copyright (c) 1982, 2009, Oracle and/or its affiliates.  All rights reserved.

连接到目标数据库: BL (DBID=680066685)

RMAN> 

已将数据文件副本列入目录

数据文件副本文件名=F:/BACKUP/USERS01.DBF RECID=3 STAMP=724063951

RMAN> 

已编目的归档日志

归档日志文件名=F:/BACKUP/BL_ARC0000000017_0723658881.0001 RECID=14 STAMP=724063994

RMAN>

已列入目录的控制文件副本

控制文件副本文件名=F:/BACKUP/BL-2010-7-11.CTL RECID=4 STAMP=724064022

。 RMAN将重写与编写目录的信息冲突的已存在的目录信息。 如果需要移动备份集片的位置,也可以使用该命令。

RMAN> list backup;

备份集列表

===================

BS 关键字  大小       设备类型占用时间 完成时间

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

3       7.50K      DISK        00:00:01     07-7月 -10

        BP 关键字: 3   状态: AVAILABLE  已压缩: NO  标记: TAG20100707T201132

段名:F:/BACKUP/BL_03LI7BVK_1_1.BAK

RMAN> catalog backuppiece 'f:/BL_03LI7BVK_1_1.BAK';

已将备份片段列入目录

备份片段句柄=F:/BL_03LI7BVK_1_1.BAK RECID=12 STAMP=724064512

也可以使用带有start with 选项的catalog命令,该命令允许定义包含将要编写目录的RMAN 备份集片的目录,RMAN 然后对该目录中的所有备份集片编写目录。

RMAN>catalog start with 'f:/backup';

。该命令也允许对一些具有类似名称的备份集片编写目录。

当使用catalog start with命令时,不会局限与特定的文件编写目录;该命令将尝试对符合参数列表的所有文件编写目录。 然后,在执行catalog过程中,非备份集片的文件将会使编写目录的过程失败,并且产生一个错误,如果作为备份集片文件被成功编写目录,则不管是否会产生其他错误。


    
 
 

您可能感兴趣的文章:

 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • rman备份脚本和rman增量备份脚本分享
  • Oracle数据库备份和恢复工具 RMan
  • catalog方式的rman备份与恢复示例
  • rman配置及rman常用命令操作
  • win平台oracle rman备份和删除dg备库归档日志脚本
  • linux自动运行rman增量备份脚本
  • 9i下RMAN的备份及恢复步骤
  • Oracle相关:Rman Crosscheck删除失效归档
  • ORACLE 数据库RMAN备份恢复
  • rman恢复方案和oracle异机恢复
  • Oracle RMAN快速入门指南


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3