2016-04-22 23:57:10
来 源
中存储网
Oracle教程
1. WHAT IS RMAN?什么是RMAN? 2. TERMINOLOGY专业词汇解释 2.1. BACKUP SETS备份集合 2.2. BACKUP PIECES备份片 2.3. IMAGE COPIES镜像备份 2.4. FULL BACKUP SETS全备份集合 2.5. INCREMENTAL BACKUP SETS增量备份集合 2.6. FILE MULTIPLEXING 2.7. RECOVE

1. WHAT IS RMAN? 什么是RMAN?

2. TERMINOLOGY 专业词汇解释

2.1. BACKUP SETS 备份集合

2.2. BACKUP PIECES 备份片

2.3. IMAGE COPIES 镜像备份

2.4. FULL BACKUP SETS 全备份集合

2.5. INCREMENTAL BACKUP SETS 增量备份集合

2.6. FILE MULTIPLEXING

2.7. RECOVERY CATALOG RESYNCING 恢复目录同步

3. THE RECOVERY CATALOG 恢复目录

3.1.恢复目录的概念

3.2.建立恢复目录

3.3.使用恢复目录的优势

4. STARTING RMAN 启动RMAN

4.1.使用不带恢复目录的RMAN

4.2.使用带恢复目录的RMAN

4.3.使用RMAN

5.注册或者注销目标数据库

5.1.注册目标数据库

5.2.注销目标数据库

6.将已有的备份操作

6.1.加入目录数据库

6.2.从目录数据库中删除

7.在非归档模式下备份

7.1.数据库完全备份的例子

7.2.备份表空间的例子

7.3.备份单独数据文件

7.4.备份数据文件

7.5.备份控制文件

8.归档模式下的备份

8.1. BACKING UP ARCHIVED LOGS 备份归档日志

8.2. BACKING UP THE ONLINE LOGS 备份联机日志

9. INCREMENTAL BACKUPS 增量备份

9.1. LEVEL 0——增量备份策略的基础

9.2. 使用增量备份的案例

10. RECOVERY 恢复

10.1. DATABASE OPEN,DATAFILE DELETED 数据库打开时,文件被删除

10.2. COMPLETE RESTORE (LOST ONLINE REDO) AND ROLLFORWARD - DATABASE CLOSED 完全还原(丢失联机日志)并且前滚 - 数据库关闭

10.3. RESTORE OF A SUBSET OF DATAFILES, COMPLETE RECOVERY 还原数据文件的子集,完全恢复

11. SCRIPTS 脚本

12. CORRUPTION DETECTION

13. CHANNELS 通道

14. REPORT & LIST COMMANDS

14.1. LIST

14.2. REPORT

15. 小提示

1. What is RMAN? 什么是RMAN?

RMAN可以用来备份和还原数据库文件、归档日志和控制文件。它也可以用来执行完全或不完全的数据库恢复。

注意:RMAN不能用于备份初始化参数文件和口令文件。

RMAN启动数据库上的Oracle服务器进程来进行备份或还原。备份、还原、恢复是由这些进程驱动的。

RMAN可以由OEM的Backup Manager GUI来控制,但在本文章里不作重点讨论。

2. Terminology 专业词汇解释

2.1. Backup sets 备份集合

备份集合有下面的特性:

Ø  包括一个或多个数据文件或归档日志

Ø  以oracle专有的格式保存

Ø  有一个完全的所有的备份片集合构成

Ø  构成一个完全备份或增量备份

2.2. Backup pieces 备份片

一个备份集由若干个备份片组成。每个备份片是一个单独的输出文件。一个备份片的大小是有限制的;如果没有大小的限制, 备份集就只由一个备份片构成。备份片的大小不能大于使用的文件系统所支持的文件长度的最大值。

2.3. Image copies 镜像备份

镜像备份是独立文件(数据文件、归档日志、控制文件)的备份。它很类似操作系统级的文件备份。它不是备份集或 备份片,也没有被压缩。

2.4. Full backup sets 全备份集合

全备份是一个或多个数据文件中使用过的数据块的的备份。没有使用过的数据块是不被备份的,也就是说,oracle 进行备份集合的压缩。 

2.5. Incremental backup sets 增量备份集合

增量备份是指备份一个或多个数据文件的自从上一次同一级别的或更低级别的备份以来被修改过的数据块。 与完全备份相同,增量备份也进行压缩。

2.6. File multiplexing

不同的多个数据文件的数据块可以混合备份在一个备份集中。

2.7. Recovery catalog resyncing 恢复目录同步

使用恢复管理器执行backup、copy、restore或者switch命令时,恢复目录自动进行更新,但是有关日志与归档日志信息没有自动记入恢复目录。需要进行目录同步。使用resync catalog命令进行同步。

RMAN>resync catalog;

RMAN-03022:正在编译命令:resync

RMAN-03023:正在执行命令:resync

RMAN-08002:正在启动全部恢复目录的 resync

RMAN-08004:完成全部 resync

3. The recovery catalog 恢复目录

3.1.恢复目录的概念

恢复目录是由RMAN使用、维护的用来放置备份信息的仓库。RMAN利用恢复目录记载的信息去判断如何执行需要的备份恢复操作。

恢复目录可以存在于ORACLE数据库的计划中。

虽然恢复目录可以用来备份多个数据库,建议为恢复目录数据库创建一个单独的数据库。

恢复目录数据库不能使用恢复目录备份自身。

3.2.建立恢复目录

第一步,在目录数据库中创建恢复目录所用表空间:

SQL> create tablespace rman_ts datafile 'd:oracleoradatarmanrman_ts.dbf' size 20M;

表空间已创建。

第二步,在目录数据库中创建RMAN 用户并授权:

SQL> create user rman identified by rman default tablespace rman_ts temporary tablespace temp quota unlimited on rman_ts;

用户已创建。

SQL> grant recovery_catalog_owner to rman ;

授权成功。

SQL> grant connect, resource to rman ;

授权成功。

第三步,在目录数据库中创建恢复目录

C:>rman catalog rman/rman

恢复管理器:版本8.1.6.0.0 - Production

RMAN-06008:连接到恢复目录数据库

RMAN-06428:未安装恢复目录

RMAN>create catalog tablespace rman_ts;

RMAN-06431:恢复目录已创建

注意:虽然使用RMAN不一定必需恢复目录,但是推荐使用。因为恢复目录记载的信息大部分可以通过控制文件来记载,RMAN在恢复数据库时使用这些信息。不使用恢复目录将会对备份恢复操作有限制。

3.3.使用恢复目录的优势

Ø 可以存储脚本;

Ø 记载较长时间的备份恢复操作;

4. Starting RMAN 启动RMAN

RMAN为交互式命令行处理界面,也可以从企业管理器中运行。

为了使用下面的实例,先检查环境符合:

Ø the target database is called "his" and has the same TNS alias

Ø user rman has been granted "recovery_catalog_owner "privileges

Ø 目标数据库的连接用户为internal帐号,或者以其他SYSDBA类型帐号连接

Ø the recovery catalog database is called "rman" and has the same TNS alias

Ø the schema containing the recovery catalog is "rman" (same password)

在使用RMAN前,设置NLS_DATE_FORMAT 和NLS_LANG环境变量,很多RMAN LIST命令的输出结果是与日期时间相关的,这点在用户希望执行以时间为基准的恢复工作也很重要。

下例是环境变量的示范:

NLS_LANG= SIMPLIFIED CHINESE_CHINA.ZHS16GBK

NLS_DATE_FORMAT=DD-MON-YYYY HH24:MI:SS

为了保证RMAN使用时能连接恢复目录,恢复目录数据库必须打开,目标数据库至少要STARTED(unmount),否则RMAN会返回一个错误,目标数据库必须置于归档模式下。

4.3.使用RMAN

C:Documents and SettingsAdministrator>rman target sys/oracle@oracle9i catalog

rman/rman

恢复管理器: 版本9.2.0.1.0 - Production

Copyright (c) 1995, 2002, Oracle Corporation.  All rights reserved.

连接到目标数据库: ORACLE9I (DBID=3307434422)

连接到恢复目录数据库

RMAN> register database;

注册在恢复目录中的数据库

正在启动全部恢复目录的 resync

完成全部 resync

RMAN>使用脚本的实例:

RMAN> execute script alloc_1_disk;

创建或者替代存储的脚本:

RMAN> replace script alloc_1_disk { 
       2> allocate channel d1 type disk;
       3> }

5.注册或者注销目标数据库

5.1.注册目标数据库

5.2.注销目标数据库

RMAN提供了一个注销工具,叫DBMS_RCVCAT工具包,请注意一旦注销了该目标数据库,就不可以使用恢复目录中含有的备份集来恢复数据库了。

为了能注销数据库,需要获得数据库的标识码(DB_ID)和数据库键值(DB_KEY)。其中连接目标数据库时将会获得DB_ID。

C:>rman target sys/oracle@oracle9i catalog rman/rman

恢复管理器:版本8.1.6.0.0 - Production

RMAN-06005:连接到目标数据库:oracle9i (DBID=3021445076)

RMAN-06008:连接到恢复目录数据库

其中DBID=3307434422,利用DBID=3307434422查询数据库键值码:

连接到目标数据库,查询db表:

SQL> select * from db;

DB_KEY      DB_ID      CURR_DBINC_KEY

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

1        3021445076              2

获得DB_KEY=1,这样,该目标数据库DB_KEY=1,DBID=3307434422,利用两个值使用DBMS_RCVCAT工具包就可以注销数据库:

SQL> execute dbms_rcvcat.unregisterdatabase(1,3021445076);

PL/SQL 过程已成功完成。

至此,注销数据库操作完成。

Drop user rman cascade;注销用户

6.将已有的备份操作

6.1.加入目录数据库

数据库状态:

Ø  恢复目录:打开

Ø  目标数据库:加载或者打开

如果存在8.x版本以前创建的备份数据想注册到目标数据库,可以采用如下手工方式加入到恢复目录中,

RMAN> catalog datafilecopy '/oracle/ .... /system01.dbf'; 
使用如下命令显示恢复目录中包含的文件

RMAN> list copy of database;

6.2.从目录数据库中删除

第一步:查看备份信息:

RMAN>list backup;

RMAN-03022:正在编译命令:list

备份集列表

关键字     Recid      标记    LV  集合标记   集合计数    完成时间

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

1104    2          501364455  0  501364446  2          06-8月 -03

备份段列表

关键字  Pc# Cp# 状态        完成时间               段名

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

1106    1   1   AVAILABLE   06-8月 -03             D:ORACLEORA81DATABASE

02EU4DMU_1_1

数据文件包括列表

文件 名称                                  LV 类型 检查点SCN  检查点时间

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

3    D:ORACLEORADATAHISUSERS01.DBF     0  Full 160052     06-8月 -03

备份集的关键字为1104。

第二步:定义delete通道:

RMAN>allocate channel for delete type disk;

RMAN-03022:正在编译命令:allocate

RMAN-03023:正在执行命令:allocate

RMAN-08030:分配的通道:delete

RMAN-08500:通道 delete:sid=19 devtype=DISK

第三步:删除backupset备份集

RMAN>change backupset 1104 delete;

RMAN-03022:正在编译命令:change

RMAN-08073:已删除备份段

RMAN-08517:备份段 handle=D:ORACLEORA81DATABASE2EU4DMU_1_1 recid=2 stamp=50

1364447

RMAN-03023:正在执行命令:partial resync

RMAN-08003:启动部分恢复目录的 resync

RMAN-08005:完成部分 resync

注意:部分执行删除备份集、备份片或者维护恢复目录的命令,需要先指定通道,如:

RMAN>allocate channel for delete type disk;

或者RMAN>allocate channel for maintenance type disk;

7.在非归档模式下备份

数据库状态:

Ø  恢复目录: 打开

Ø  目标数据库:例程启动或者数据库加载

恢复目录数据库需要打开,目标数据库必须启动(或者加载)。因为目标数据库不在归档模式下,所以当进行备份恢复操作的时候数据库无法打开。不可以将表空间置于热备份模式上进行等同于文件系统级的拷贝,如果在非归档模式,数据库打开的状态下不能进行数据文件的备份。

7.1.数据库完全备份

RMAN> run {
     2> # backup the complete database to disk
     3> allocate channel dev1 type disk;
     4> backup
     5>   full
     6>   tag full_db_backup
     7>   format '/oracle/backups/db_t%t_s%s_p%p'
     8>   (database);
     9> release channel dev1;
     10> }

行#
        2: 表明该行为注释行(#是注释符)

3&9: See section 15 – Channels通道定义

5: Full backup (default if full or incremental not specified)完全备份模式(缺省模式)

6: Meaningful string (<=30 chars)(备份集标识,<=30个字符)

7: Filename to use for backup pieces, including substitution variables. 备份片使用的文件名,可以包含代替变量。

8: Indicates all files including controlfiles are to be backed up表明备份所有数据文件包括控制文件

详细:

RMAN> run {

2> allocate channel dev type disk;

3> backup

4> full

5> tag full_db_backup

6> format 'e:rmanbkdb_t%t_s%s_p%p'

7> (database);

8> release channel dev1;

9> }

分配的通道: dev

通道 dev: sid=18 devtype=DISK

启动 backup 于 01-2月 -08

通道 dev: 正在启动 full 数据文件备份集

通道 dev: 正在指定备份集中的数据文件

在备份集中包含当前的 SPFILE

备份集中包括当前控制文件

输入数据文件 fno=00001 name=E:ORACLEORADATAORACLE9ISYSTEM01.DBF

输入数据文件 fno=00002 name=E:ORACLEORADATAORACLE9IUNDOTBS01.DBF

输入数据文件 fno=00005 name=E:ORACLEORADATAORACLE9IEXAMPLE01.DBF

输入数据文件 fno=00010 name=E:ORACLEORADATAORACLE9IXDB01.DBF

输入数据文件 fno=00006 name=E:ORACLEORADATAORACLE9IINDX01.DBF

输入数据文件 fno=00009 name=E:ORACLEORADATAORACLE9IUSERS01.DBF

输入数据文件 fno=00003 name=E:ORACLEORADATAORACLE9ICWMLITE01.DBF

输入数据文件 fno=00004 name=E:ORACLEORADATAORACLE9IDRSYS01.DBF

输入数据文件 fno=00007 name=E:ORACLEORADATAORACLE9IODM01.DBF

输入数据文件 fno=00011 name=E:ORACLEORADATATEST.DBF

输入数据文件 fno=00013 name=E:ORACLEORADATATEST2.DBF

输入数据文件 fno=00014 name=E:ORADATARMANRMAN_TS.DBF

输入数据文件 fno=00008 name=E:ORACLEORADATAORACLE9ITOOLS01.DBF

输入数据文件 fno=00012 name=E:ORACLEORADATATEST1.DBF

通道 dev: 正在启动段 1 于 01-2月 -08

通道 dev: 已完成段 1 于 01-2月 -08

段 handle=E:RMANBKDB_T645494771_S1_P1 comment=NONE

通道 dev: 备份集已完成, 经过时间:00:01:37

完成 backup 于 01-2月 -08

释放的通道: dev

RMAN-00571: ===========================================================

RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============

RMAN-00571: ===========================================================

RMAN-03002: failure of release command at 02/01/2008 00:07:49

RMAN-06012: channel: dev1 not allocated

RMAN> list backup

2> ;

备份集列表

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

BS 关键字  类型 LV 大小       设备类型 经过时间 完成时间

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

123     Full    515M       DISK        00:01:35     01-2月 -08

BP 关键字: 124   状态: AVAILABLE   标记:FULL_DB_BACKUP

段名:E:RMANBKDB_T645494771_S1_P1

包含的 SPFILE: 修改时间: 06-1月 -08

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

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

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

1       Full 2019884    01-2月 -08 E:ORACLEORADATAORACLE9ISYSTEM01.DBF

2       Full 2019884    01-2月 -08 E:ORACLEORADATAORACLE9IUNDOTBS01.DBF

3       Full 2019884    01-2月 -08 E:ORACLEORADATAORACLE9ICWMLITE01.DBF

4       Full 2019884    01-2月 -08 E:ORACLEORADATAORACLE9IDRSYS01.DBF

5       Full 2019884    01-2月 -08 E:ORACLEORADATAORACLE9IEXAMPLE01.DBF

6       Full 2019884    01-2月 -08 E:ORACLEORADATAORACLE9IINDX01.DBF

7       Full 2019884    01-2月 -08 E:ORACLEORADATAORACLE9IODM01.DBF

8       Full 2019884    01-2月 -08 E:ORACLEORADATAORACLE9ITOOLS01.DBF

9       Full 2019884    01-2月 -08 E:ORACLEORADATAORACLE9IUSERS01.DBF

10      Full 2019884    01-2月 -08 E:ORACLEORADATAORACLE9IXDB01.DBF

11      Full 2019884    01-2月 -08 E:ORACLEORADATATEST.DBF

12      Full 2019884    01-2月 -08 E:ORACLEORADATATEST1.DBF

13      Full 2019884    01-2月 -08 E:ORACLEORADATATEST2.DBF

14      Full 2019884    01-2月 -08 E:ORADATARMANRMAN_TS.DBF

通过下面的命令显示恢复目录中记载的备份集信息:

RMAN> list backupset of database;

7.2.备份表空间

RMAN> run {
     2> allocate channel dev1 type disk;
     3> backup
     4>   tag tbs_users_read_only
     5>   format '/oracle/backups/tbs_users_t%t_s%s'

6>   (tablespace users)
     7> }

使用下列命令来显示恢复目录中该表的备份信息:

RMAN> list backupset of tablespace users;

假设USERS表空间在备份后被置为READ ONLY表空间,以后的全库备份就可以不用备份该表空间,为了达到这个目的,可以在以后的备份中指定'skip readonly'。

注意,目标数据库不需要一定打开,只要加载就可以,因为表空间的信息存储在控制文件中。

7.3.备份单独数据文件

RMAN> run {
     2> allocate channel dev1 type 'SBT_TAPE';
     3> backup
     4>   format '%d_%u'
     5>   (datafile '/oracle/dbs/sysbigdb.dbf');
     6> release channel dev1;
     7> }

行#
         2: 使用MML(media manager layer)分配磁带驱动器,必须指定类型为SBT_TAPE;

注意因为没有指定标识,所以标识为空;

使用下面的命令显示恢复目录中备份的表空间:

RMAN> list backupset of datafile 1;

7.4.备份数据文件

RMAN> run {

2> allocate channel dev1 type 'SBT_TAPE';

3>  copy datafile '/oracle/dbs/temp.dbf' to '/oracle/backups/temp.dbf';

4> release channel dev1;

5> }

使用下面的命令显示恢复目录中的文件拷贝:

RMAN> list copy of datafile '/oracle/dbs/temp.dbf';

拷贝数据文件和备份数据文件是不一样的,数据文件拷贝是一个该文件的镜像。文件的备份产生一个备份集。

7.5.备份控制文件

RMAN> run { 
     2> allocate channel dev1 type 'SBT_TAPE';
     3> backup
     4>   format 'cf_t%t_s%s_p%p'
     5>   tag cf_monday_night
     6>   (current controlfile);
     7> release channel dev1;
     8> }

注意:数据库完全备份将自动备份控制文件。     

8.归档模式下的备份

数据库状态:

恢复目录:打开
       目标数据库:例程启动,数据库加载或者打开

备份操作使用的命令与非归档模式下基本一样。

8.1. Backing up archived logs 备份归档日志

下面的脚本备份归档日志:

RMAN> run {
     2> allocate channel dev1 type disk;
     3> backup
     4>   format '/oracle/backups/log_t%t_s%s_p%p'
     5>   (archivelog all);
     6> release channel dev1;
     7> }

下面的脚本归档日志从# 90 to 100:

RMAN> run {
     2> allocate channel dev1 type disk;
     3> backup
     4>   format '/oracle/backups/log_t%t_s%s_p%p'
     5>   (archivelog from logseq=90 until logseq=100 thread 1);
     6> release channel dev1;
     7> }

下面的脚本备份在24小时内产生的归档日志,在备份完成后会自动删除归档日志。如果备份失败,归档日志不会被删除。

RMAN> run {
     2> allocate channel dev1 type disk;
     3> backup
     4>   format '/oracle/backups/log_t%t_s%s_p%p'
     5>   (archivelog from time 'sysdate-1' all delete input);
     6> release channel dev1;
     7> }

使用下面的命令显示恢复目录中的归档日志:

RMAN> list backupset of archivelog all;

注意:RMAN找到归档日志后会备份指定日志,如果无法找到日志,它也不会返回错误信息。

8.2. Backing up the online logs 备份联机日志

联机日志不能用RMAN来备份,必须先将其归档。

为了实现这点,必须在RMAN中执行如下SQL语句:

RMAN> run {
     2> allocate channel dev1 type disk;
     3> sql "alter system archive log current";
     4> backup
     5>   format '/oracle/backups/log_t%t_s%s_p%p'
     6>   (archivelog from time 'sysdate-1' all delete input);
     7> release channel dev1;
     8> }

上面的脚本可以在执行完一个完整的联机数据库备份后执行,确保所有的重做日志可以将数据库恢复到一个一致性的状态。

注意:不可以标识归档日志备份集。

9. Incremental backups 增量备份

N级别增量备份备份从最近的N级别或者更小级别以来的所有更改过的数据块内容。

增量备份分为两种,一种是累积增量备份,一种是非累积增量备份。

Ø  累积增量备份包括自最后一次在更低级别进行备份以来所有改动过的数据块。

Ø  非累积增量备份包括自前一次在同级或者更低级别进行备份以来改动过的数据块。

9.1. Level 0——增量备份策略的基础

Level 0 是增量备份策略的基础——the basis of the incremental backup strategy

RMAN> run {
     2> allocate channel dev1 type disk;
     3> backup
     4>   incremental level 0
     5>   filesperset 4
     6>   format '/oracle/backups/sunday_level0_%t'
     7>   (database);
     8> release channel dev1;
     9> }

Line#
        4: 0级备份
        5: 定义每个backupset 的最大文件数

使用LIST语句查看,数据库备份集的列表显示中, 'type' 将显示  'Incremental','LV'列将显示'0' 。  

9.2. 使用增量备份的案例

一个典型的增量备份案例如下:

Ø  星期天晚上 - level 0 backup performed

Ø  星期一晚上 - level 2 backup performed

Ø  星期二晚上 - level 2 backup performed

Ø  星期三晚上 - level 1 backup performed

Ø  星期四晚上 - level 2 backup performed

Ø  星期五晚上 - level 2 backup performed

Ø  星期六晚上 - level 2 backup performed

Ø  星期天晚上 - level 0 backup performed

10. Recovery 恢复

恢复案例如下:

    10.1. Database open,datafile deleted 数据库打开时,文件被删除

数据文件在数据库打开时被删除。有两种方法可以对打开的数据库进行恢复:还原数据文件或者表空间。下面两个实例显示了该方法:

(a) Datafile recovery 数据文件恢复

RMAN> run {
       2> allocate channel dev1 type disk;
       3> sql "alter tablespace users offline immediate";
       4> restore datafile 4;
       5> recover datafile 4;
       6> sql "alter tablespace users online";
       7> release channel dev1;
       8> }
    

(b) Tablespace recovery 表空间恢复

RMAN> run {
       2> allocate channel dev1 type disk;
       3> sql "alter tablespace users offline immediate";
       4> restore tablespace users;
       5> recover tablespace users;
       6> sql "alter tablespace users online";
       7> release channel dev1;
       8> }

注意:如果还原系统表空间文件,数据库必须关闭,因为系统表空间不可以脱机。

    10.2. Complete restore (lost online redo) and rollforward - database closed 完全还原(丢失联机日志)并且前滚 -数据库关闭

RMAN> run {
       2> allocate channel dev1 type disk;
       3> set until logseq=105 thread=1;
       4> restore controlfile to '/oracle/dbs/ctrltargdb.ctl';
       5> replicate controlfile from '/oracle/dbs/ctrltargdb.ctl';
       6> restore database;
       7> sql "alter database mount";
       8> recover database;
       9> sql "alter database open resetlogs";
       10> release channel dev1;
       11> }

Notes:

'set until' 命令指明恢复到指定的日志文件。这一点在数据文件恢复时很重要,否则RMAN将试图恢复最近的数据文件,该数据文件可能在指定的日志以前。

'replicate controlfile' 复制还原的控制文件到INIT.ORA指定的控制文件。

如果数据库使用WITH RESETLOGS打开,则需要使用RESET DATABASE命令注册改变后的数据库。在使用RESETLOGS命令打开数据库后强烈建议做一个完全的数据库备份。

    10.3. Restore of a subset of datafiles, complete recovery 还原数据文件的子集,完全恢复

RMAN> run {
       2> allocate channel dev1 type disk;
       3> sql "alter database mount";
       4> restore datafile 2;
       5> restore datafile 3;
       6> restore archivelog all;
       7> recover database;
       8> sql "alter database open";
       9> release channel dev1;
       10> }

11. Scripts 脚本

创建或者取代脚本:

RMAN> create script alloc_disk {
   2> # Allocates one disk
   3> allocate channel dev1 type disk;
   4> setlimit channel dev1 kbytes 2097150 maxopenfiles 32 readrate 200;
   5> }
  

RMAN> replace script rel_disk {
   2> # releases disk
   3> release channel dev1;
   5> }
  

RMAN> replace script backup_db_full {
   2> # Performs a complete backup 
   3> execute script alloc_disk;
   4> backup
   5> .....<backup commands here>
   6> execute script rel_disk;
   7> }

前两个脚本分别用来分配和回收通道。

alloc_disk 脚本还额外指定了备份片的最大兆字节数,备份时可以同时打开的输入文件的最大数目,以及每秒钟读每个输入文件的数据缓冲区的最大数目。

第三个脚本调用先前存储的两个脚本进行数据库备份。

运行存储脚本的示范:

RMAN> run {
   2> execute script backup_db_full;
   3> }

注意:存储的脚本必须在{ .... execute <script>; ....}命令中调用。

12. Corruption detection  

RMAN可以备份包含损坏数据块的数据文件,查询视图V$BACK_CORRUPTION和V$COPY_CORRUPTION可以获得有关坏数据的信息。

通过设置 set maxcorrupt 可以跳过指定个数的坏块来避免备份失败。

RMAN> replace script backup_db_full {
   2> # Performs a complete backup
   3> execute script alloc_disk;
   4> set maxcorrupt for datafile 1 to 0;
   5> backup
   6> .....<backup commands here>
   7> execute script rel_disk;
   8> }

上面的脚本maxcorrupt for datafile 1 to 0设置为0,所以如果有错误数据块在数据文件1中发现,上面的脚本执行就会失败。

13. Channels 通道

一个通道是RMAN和目标数据库之间的一个连接,'allocate   channel'命令在目标数据库启动一个服务器进程,同时必须定义服务器进程执行备份或者恢复操作使用的I/O类型

通道控制命令可以用来:

Ø   控制RMAN使用的O/S资源

Ø   影响并行度

Ø   指定I/O带宽的限制值(设置limit read rate参数)

Ø   定义备份片大小的限制(设置limit kbytes)

Ø   指定当前打开文件的限制值(设置limit maxopenfiles)

14. Report & list commands

    14.1. List

list命令查询恢复目录并且产生格式化的查询内容:

RMAN> list backupset of datafile 1;

Key     File Type         LV Completion_time Ckp SCN    Ckp Time
  ------- ---- ------------ -- --------------- ---------- --------
 165     1    Full            Oct 03 11:24    32022      Oct 03 11:24
 208     1    Full            Oct 24 14:27    52059      Oct 24 14:26
 219     1    Full            Oct 24 14:31    52061      Oct 24 14:31
      << other entries here >>
    

RMAN> list backupset of archivelog all;
     Key     Thrd Seq     Completion time
    ------- ---- ------- ---------------
     179     1    94      Oct 03 11:26
     179     1    95      Oct 03 11:26
      << other entries here >>

    14.2. Report

REPORT命令同样可以查询恢复目录,但是REPORT命令语法可以构建获得更为有用的信息的指令,REPORT命令输出可以保存到消息日志文件中,但是必须在连接恢复目录时指定MSGLOG或者LOG选项。

可以列出所有数据库中不能恢复的文件列表:

RMAN> report unrecoverable database;

显示全部数据文件:

RMAN>report schema;

RMAN-03022:正在编译命令:report

数据库模式报表

文件 千字节     表空间               RB segs 名称

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

1        121472 SYSTEM              YES    D:ORACLEORADATAHISSYSTEM01.DBF

2        327680 RBS                  YES    D:ORACLEORADATAHISRBS01.DBF

3        110592 USERS                NO     D:ORACLEORADATAHISUSERS01.DBF

4         73728 TEMP                 NO     D:ORACLEORADATAHISTEMP01.DBF

5         12288 TOOLS                NO     D:ORACLEORADATAHISTOOLS01.DBF

6         59392 INDX                 NO     D:ORACLEORADATAHISINDX01.DBF

15. 小提示

Ø  经常同步恢复目录

Ø  确认删除不需要的归档日志

Ø  备份策略简单原则

注:

网上有不少朋友对RMAN的用法和概念提出了疑问。

这篇文章主要介绍RMAN的常用方法,其中包含了作者一些自己的经验,里面的实验也基本全在WIN 2K和ORACLE 8.1.6环境下测试成功(因为这个环境比较容易实现)。

本文借鉴了网上一些高手的相关文章,希望大侠们不要见怪,此处一并谢过。

这篇文章主要是在北京出差期间写的,回到家后整理修改了一下,时间比较仓促,同时因为篇幅有限,一些技术细节不能一一覆盖了,只希望能够帮助新手入门的作用,想真正熟练掌握RMAN,必须经过较长时间的实践磨练才可以,尤其需要在工程中获得宝贵的故障解决经验。

本人水平有限,还望众多高手指出不足之处,不胜感谢!

您可以在非商业用途范围内任意传播此文档,但请不要更改里面的内容。

作者:Sandybillows

MSN: shatao2000@hotmail.com

声明: 此文观点不代表本站立场;转载须要保留原文链接;版权疑问请联系我们。