Oracle RMAN 详解与实例

1. 检查数据库模式:

  sqlplus/nolog

  conn /assysdba

  archivelog list (查看数据库是否处于归档模式中)


若为非归档,则修改数据库归档模式。

  startupmount

  alterdatabase archivelog

  alterdatabase open


2.连接到target数据库


命令:connect target  / (connect targetsystem/oracle@ora10g,如果数据库没有起来,也可要直接在rman命令下用startup进行启动数据库)

可以连接到targetdatabase.(rman 一边连接到target数据库,另外一边连接到controlfile(nocatalog mode),control file 中存储rman 的备份信息)


3.list backupset 命令查看有没有备份的东西


4. 常用备份命令:

备份全库:

RMAN> backup database plus archivelog deleteinput;     (备份全库及控制文件、服务器参数文件与所有归档的重做日志,并删除旧的归档日志)

备份表空间:

RMAN> backup tablespace system plus archivelogdelete input;     (备份指定表空间及归档的重做日志,并删除旧的归档日志)_

备份归档日志:

RMAN> backup archivelog all delete input;



======================对整个数据库进行备份==================


1.对整个数据库进行全备份(full backup)


只要输入命令: backupdatabase;


2.list backupset 查看备份的具体信息


List of Backup Sets

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


BS Key  Type LV Size       Device Type Elapsed Time Completion Time

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

1       Full    6.80M     DISK        00:00:02     06-DEC-08      

       BPKey: 1   Status: AVAILABLE  Compressed: NO  Tag: TAG20081206T201041

       PieceName: /home/oracle/flash_recovery_area/ORA10G/backupset/2008_12_06/o1_mf_ncsnf_TAG20081206T201041_4mntz78s_.bkp

 ControlFile Included: Ckp SCN: 782019       Ckptime: 06-DEC-08

 SPFILEIncluded: Modification time: 06-DEC-08


BS(backupset), piece是一个文件,一个BS包含多个piece.


3.rman中缺省的参数,可以通过 show all ;

来进行查看(RMANconfiguration parameters),我们在使用backup database命令中,可以把这些default value 用固定的值来进行替代.


4.我们可以把备份的文件才备份的目录中拷贝到磁带上,然后删除备份目录下面的备份文件,如果下次需要恢复的话,只要把文件重新拷回到用来的备份目录就可以了

5.查看control file 文件中的备份信息(因为我们做的备份是在nocatalog模式下),control file /u01/oracle/oradata/ora10g目录下,由于controlfile 是个二进制文件,要查看controlfile 文件中的内容,用stringscontrol03.ctl,发现control03.ctl中有rman备份的信息了



====================0级增量备份===============


概念:全备份和0级增量备份。全备份和0级增量备份几乎是一样的。唯一的区别,0级增量备份能作为增量备份的基础,而全备份不能作为增量备份的基础。其它方面完全一致


1.backup incremental level=0(leve 0) database;(增量为0的备份)

2.backup incremental level 1(level=1) database;(增量为1的备份)


在上面的备份中,我们备份了datafile,controlfileparameter file.没有备份的文件有归档日志,重做日志和口令文件没有备份.口令文件不需要备份,我们用orapw来创建一个


新的口令文件.rman nocatalog模式下,不能够对redo log file 进行备份



===================备份archivelog nocatalog模式下=================


命令:backupdatabase plus archivelog delete input(delete input的意思在备份完成后,删除archivelog文件,这个选项可要可不要,这个命令也可以用backup incremental level=0(1,2...)来进行备份)



=======================备份表空间====================


backup tablespace tablespacename


如果我们不知道tablespace的名字,在rman中,可要通过report schema命令,来查看表空间的名字


MAN> report schema;

Report of database schema


List of Permanent Datafiles

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

File Size(MB) Tablespace           RB segs Datafile Name

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

1    480      SYSTEM               ***     /home/oracle/oradata/ora10g/system01.dbf

2    25       UNDOTBS1             ***     /home/oracle/oradata/ora10g/undotbs01.dbf

3    250      SYSAUX               ***     /home/oracle/oradata/ora10g/sysaux01.dbf

4    5        USERS                ***     /home/oracle/oradata/ora10g/users01.dbf

5   200      PERFSTAT             ***     /home/oracle/oradata/ora10g/perfstat.dbf


List of Temporary Files

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

File Size(MB) Tablespace           Maxsize(MB) Tempfile Name

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

1   20       TEMP                 32767       /home/oracle/oradata/ora10g/temp01.dbf


========================备份控制文件====================


backup current controlfile


backup database include current controlfile


========================备份镜像========================


rman的备份中有两种方式:备份集(backupset)和备份镜像(image copies).镜像备份主要是文件的拷贝:copy datafile ... to ...


我们在rman>report schema;


Report of database schema


List of Permanent Datafiles

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

File Size(MB) Tablespace           RB segs Datafile Name

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

1    480      SYSTEM               ***     /home/oracle/oradata/ora10g/system01.dbf

2    25       UNDOTBS1             ***     /home/oracle/oradata/ora10g/undotbs01.dbf

3    250      SYSAUX               ***     /home/oracle/oradata/ora10g/sysaux01.dbf

4    5        USERS                ***     /home/oracle/oradata/ora10g/users01.dbf

5   200      PERFSTAT             ***     /home/oracle/oradata/ora10g/perfstat.dbf


List of Temporary Files

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

File Size(MB) Tablespace           Maxsize(MB) Tempfile Name

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

1   20       TEMP                 32767       /home/oracle/oradata/ora10g/temp01.dbf


rman>copy datafile 5 to'/u01/rmanbak/tbso1bak.dbf';(copy 5 对应的schme:perfstat.dbf)


它会把tbs作为一个拷贝。我们用list backupset来看不能够查看我们刚备份的 tbs01bak.dbf',因为它不是backupset. 我们用list copy 就能够查看我们刚才刚刚备份的文件



=======================单命令与批命令=================


单命令: backup database;


批命令:


rman> run{

2>allocate channel cha1 type disk;

3>backup

4>format '/u01/rmanbak/full_%t'

5> tagfull-backup //标签可以顺便起没关系

6>database;

7>release channel cha1;

8>}


这个run中有3条命令分别用分号来进行分割.


format:

%c备份片的拷贝数(1开始编号)

%d数据库名称

%D:位于该月中的天数(DD)

%M:位于该年中的月份(MM)

%F:一个基于DBID唯一的名称,这个格式的形式为c-xxx-YYYYMMDD-QQ,其中xxx位该数据库的DBIDYYYYMMDD为日期,QQ是一个1-256的序列;

%n:数据库名称,并且会在右侧用x字符进行填充,使其保持长度为8

%u:是一个由备份集编号和建立时间压缩后组成的8字符名称。利用%u可以为每个备份集产生一个唯一的名称;

%p:表示备份集中的备份片的编号,从1开始编号;

%U:是%u_%p_%c的简写形式,利用它可以为每一个备份片段(既磁盘文件)生成一个唯一的名称,这是最常用的命名方式;

%t:备份集时间戳;

%T:年月日格式(YYYYMMDD);


channel的概念:一个channelrman于目标数据库之间的一个连接,"allocatechannel"命令在目标数据库启动一个服务器进程,同时必须定义服务器进程执行备份和恢复操作使


用的I/O类型


通道控制命令可以用来:

控制rman使用的OS资源

影响并行度

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

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

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



=================================RMAN一周典型备份方案============================


1.星期天晚上      -level0 backup performed(全备份)

2.星期一晚上      -level2 backup performed

3.星期二晚上      -level2 backup performed

4.星期三晚上      -level1 backup performed

5.星期四晚上      -level2 backup performed

6.星期五晚上      -level2 backup performed

7.星期六晚上      -level2 backup performed



如果星期二需要恢复的话,只需要1+2,

如果星期四需要恢复的话,只需要1+4,

如果星期五需要恢复的话,只需要1+4+5,

如果星期六需要恢复的话,只需要1+4+5+6.


自动备份:备份脚本+crontab

bakl0

bakl1

bakl2


执行脚本:

rman target / msglog=bakl0.log cmdfile=bakl0 (/表示需要连接的目标数据库,msglog表示日志文件,cmdfile表示的是脚本文件)

rman target / msglog=bakl1.log cmdfile=bakl1

rman target / msglog=bakl2.log cmdfile=bakl2


实例:rmantarget system/oracle@ora10g(/) msglog=/u01/rmanbak/bakl1.log cmdfile=/u01/rmanbak/bakl0



完整的命令:/u01/oracle/product/10.2.0/bin/rmantarget system/oracle@ora10g(/) msglog=/u01/rmanbak/bakl1.logcmdfile=/u01/rmanbak/bakl0



把备份脚本放到/u01/rmanbak/script目录下面,vi bakl0,bakl0的内容为:


run{

   allocatechannel cha1 type disk;

   backup

  incremental level  0

   format'/u01/rmanbak/inc0_%u_%T'(u表示唯一的ID,T是日期,小t是时间)

   tagmonday_inc0 //标签可以顺便起,没关系

   database;

   releasechannel cha1;

   }

,类似就可以写出bakl1,bakl2相应的脚本.



自动备份

crontab

crontab -e -u oracle(改命令的意思是编辑oracle用户的定时执行(-e,edit -u oracle,oracle用户))


星期(0代表星期天)

45 23  *  *   0    rman target /msglog=bakl0.log cmdfile=bakl0(星期天的23:45会以oracle用户的身份来执行命令)

45 23  *  *   1    rman target /msglog=bakl2.log cmdfile=bakl2

45 23  *  *   2    rman target /msglog=bakl2.log cmdfile=bakl2

45 23  *  *   3    rman target /msglog=bakl1.log cmdfile=bakl1

45 23  *  *   4    rman target /msglog=bakl2.log cmdfile=bakl2

45 23  *  *   5    rman target /msglog=bakl2.log cmdfile=bakl2

45 23  *  *   6    rman target / msglog=bakl2.logcmdfile=bakl2


然后启动crontab,启动crontab的命令:

root> service crond restart


=======================RMAN恢复================


在非catalog模式下,备份的信息存储在controlfile文件中,如果controlfile文件发生毁坏,那么就不能能够进行恢复,

使用在备份的时候需要把controlfile也进行自动备份


RMAN>show all;

using target database control file instead ofrecovery catalog

RMAN configuration parameters are:

CONFIGURE RETENTION POLICY TO REDUNDANCY 1; #default

CONFIGURE BACKUP OPTIMIZATION OFF; # default

CONFIGURE DEFAULT DEVICE TYPE TO DISK; # default

CONFIGURE CONTROLFILE AUTOBACKUP OFF; # default

CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVICETYPE DISK TO '%F'; # default

CONFIGURE DEVICE TYPE DISK PARALLELISM 1 BACKUPTYPE TO BACKUPSET; # default

CONFIGURE DATAFILE BACKUP COPIES FOR DEVICE TYPEDISK TO 1; # default

CONFIGURE ARCHIVELOG BACKUP COPIES FOR DEVICE TYPEDISK TO 1; # default

CONFIGURE MAXSETSIZE TO UNLIMITED; # default

CONFIGURE ENCRYPTION FOR DATABASE OFF; # default

CONFIGURE ENCRYPTION ALGORITHM 'AES128'; # default

CONFIGURE ARCHIVELOG DELETION POLICY TO NONE; #default

CONFIGURE SNAPSHOT CONTROLFILE NAME TO'/home/oracle/product/10.20/dbs/snapcf_ora10g.f';# default


其中CONFIGURECONTROLFILE AUTOBACKUP OFF; 没有对controlfile进行 autobackup,使用我们需要运行下面命令来对controlfile进行自动备份

RMAN> CONFIGURE CONTROLFILE AUTOBACKUP ON;


RMAN> show all;


手动备份控制文件:

backup current controlfile



Dbid表示database的一个ID,将来用于恢复spfilecontrolfile时候要用到.

RMAN> connect target /

connected to target database: ORA10G (DBID=3988862108)

这个Dbid=3988862108



RMAN> list backup;查看以前备份的信息

RMAN>delete backupset 24;//24代表backupset 的编号

RMAN>backup format '/u01/rmanbak/full_%T_%U.bak'database plus archivelog;(进行一次全备份)


验证备份:

RMAN> validate backupset 3;  //3代表backupset的编号


口令文件丢失(不属于rman备份的范畴),我们只需要用一个命令来重建这个文件就可以了:

orapw file=orapwsid password=pass entries=5;  //口令文件的路径:/u01/oracle/product/10.20/db_1/dbs目录下

oracle> cd /u01/oracle/product/10.20/db_1/dbs

oracle> rm orapwora10g;(文件删除,模拟丢失)

oracle> orapwd file=orapwora10g password=oracle entries=5;(重新建立一个文件),entries的意思(DBA的用户最多有5)


SPFILE丢失:

startup nomount;

set dbid 3988862108;

restore spfile from autobackup;

shutdown immediate;

set dbid 3988862108;

startup;


模拟操作:

oracle> mv spfileora10g.ora spora10g.ora

oracle>rman target /;

rman> shutdown immediate;

rman> startup nomount;

startup failed: ORA-01078: failure in processingsystem parameters

LRM-00109: could not open parameter file'/home/oracle/product/10.20/dbs/initora10g.ora'

rman>set dbid 3988862108;

rman>restore spfile from autobackup;


执行该命令,如果没有找到的话,那可能是文件的路径发生错误.可以通过直接赋予它的文件

rman>restore spfile from'/u01/oracle/flash_recovery_area/ORA10G/autobackup/2008_12_09/o1_mf_s_673025706_4mw7xc79_.bkp


dbs/目录下产生spfileora10g.ora文件。证明spfile 已经恢复好


rman> shutdown immediate;

rman> startup ;(如果该命令不能够启动数据库,那么需要set dbid3988862108)



controlfile 丢失:

startup nomount;

restore controlfile from autobackup;

alter database mount;

recover database;

alter database open resetlogs;


注意:在做了alter databaseopen resetlogs;会把onlineredelog file清空,数据文件丢失.所以这个时候要做一个全备份。


oracle>rm *.ctl

oracle>rman target / ;//不能够连接到rman ,因为controlfile丢失

oracle>sqlplus /nolog;



SQL>shutdown immediate; //因为controlfile丢失,不能够正常shutdown

SQL>shutdown abort;


oracle>rman target /;


rman>startup nomount;

rman>restore controlfile from autobackup;

rman>alter database mount;

rman>alter database open resetlogs;


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

RMAN-00569: =============== ERROR MESSAGE STACKFOLLOWS ===============

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

RMAN-03002: failure of alter db command at12/09/2008 16:21:13

ORA-01194: file 1 needs more recovery to beconsistent

ORA-01110: data file 1: '/home/oracle/oradata/ora10g/system01.dbf


//出错, redo logscn记录在controlfile里面的,因为我们有新的controlfile,所以需要resetlogs;


/*

resetlogs命令表示一个数据库逻辑生存期的结束和另一个数据库逻辑生存期的开始,每次使用resetlogs命令的时候,SCN不会被重置,不过oracle会重置日志序列号,而且会重置


联机重做日志内容.

这样做是为了防止不完全恢复后日志序列会发生冲突(因为现有日志和数据文件间有了时间差)。

*/

rman>recover database;

rman>alter database open resetlogs;



Redolog file丢失:(下面的这些语句一定要在sqlplus中执行,不是在rman中执行)

(sqlplus/nolog)

1.shutdown immediate;

2.startup mount;

3.recover database until cancel;(media recovery)

4.alter database resetlogs;


数据文件丢失(rman中执行sql语句,在sql后面用双引号括起来):

1. sql "alter database datafile 3offline";

2. restore datafile 3

3. recover datafile 3

4. sql "alter database datafile 3online";


表空间丢失:

1. sql "alter tablespace usersoffline";//如果文件不存在,则用 sql"alter tablespace users offline immeidate";

2. restore tablespace users;

3. recover tablespace users; //online redologfile 信息一致

4. sql "alter tablespace users online";


catalog方式完全恢复


数据库出现问题:


1.startup nomount;

2.restore controlfile from autobackup;

3.alter database mount;

4.restore database;

5.recover database;

6.alter database open resetlogs;


模拟操作:

oracle ora10g>rm *;

oracle ora10g>ls;

oracle ora10g>  //数据文件,控制文件全部删除


oracle ora10g>rman target /; //因为controlfile丢失,不能够连接到rman

oracle ora10g>sqlplus /nolog;

oracle ora10g>connect / as sysdba;

oracle ora10g>shutdown abort;

oracle ora10g>rman target /


rman> startup nomount;

rman> restore controlfile from autabackup;

rman> alter database mount;

rman> restore database;

rman> recover database; //online redolog 不存在


SQL>recover database until cancel; //redo log丢失,数据库在缺省的方式下,是不容许进行recover操作的,那么如何在这种情况下操作呢

SQL>create pfile from spfile;


vi /u01/product/10.20/dbs/initora10g.ora,在这个文件的最后一行添加

*.allow_resetlogs_corruption='TRUE'; //容许resetlogcorruption



SQL>shutdown immediate;

SQL>startuppfile='/u01/product/10.20/dbs/initora10g.ora'mount;

SQL>alter database open resetlogs;


基于时间点的恢复:

run{

 set untiltime "to_date(07/01/02 15:00:00','mm/dd/yy hh24:mi:ss')";

 restoredatabase;

 recoverdatabase;

 alterdatabase open resetlogs;

}


ALTER SESSION SET NLS_DATE_FORMAT='YYYY-MM-DDHH24:MI:SS';

1.startup mount;

2.restore database until time"to_date('2009-7-19 13:19:00','YYYY-MM-DD HH24:MI:SS')";

3.recover database until time"to_date('2009-7-19 13:19:00','YYYY-MM-DD HH24:MI:SS')";

4.alter database open resetlogs;


如果有openresetlogs,都是不完整恢复.


基于 SCN的恢复:

1.startup mount;

2.restore database until scn 10000;

3.recover database until scn 10000;

4.alter database open resetlogs;



基于日志序列的恢复:

1.startup mount;

2.restore database until SEQUENCE 100 thread 1;//100是日志序列

3.recover database until SEQUENCE 100 thread 1;

4.alter database open resetlogs;


日志序列查看命令:SQL>select * from v$log;其中有一个sequence字段.resetlogs就会把sequence 置为1



=================================RMAN catalog模式下的备份与恢复=====================


1.创建Catalog所需要的表空间

SQL>create tablespace rman_ts size datafile'/u01/oracle/oradata/ora10g/rmants.dbf'20M;



2.创建RMAN用户并授权

SQL>create user rman identified by rman defaulttablespace rman_ts quota unlimited on rman_ts;

SQL>grant recovery_catalog_owner to rman;(grantconnect to rman)



查看角色所拥有的权限:select * from dba_sys_privs where grantee='RECOVERY_CATALOG_OWNER';

(RECOVER_CATALOG_OWNER,CONNECT,RESOURCE)


3.创建恢复目录

oracle>rman catalog rman/rman

RMAN>create catalog tablespace rman_ts;

RMAN>register database;(databasetarget database)


database registered in recovery catalog

starting full resync of recovery catalog

full resync complete


RMAN> connect target /;


以后要使用备份和恢复,需要连接到两个数据库中,命令:


oracle>rman target / catalog rman/rman (第一斜杠表示target数据库,catalog表示catalog目录 rman/rman表示catalog用户名和密码)


命令执行后显示:


Recovery Manager: Release 10.2.0.1.0- Production on Wed Dec 10 15:00:42 2008

Copyright (c) 1982, 2005, Oracle.  All rights reserved.

connected to target database: ORA10G (DBID=3988862108)

connected to recovery catalog database



命令解释:

Report schema              Report shema是指在数据库中需找schema

List backup                   control读取信息

Crosscheck backup       看一下backup的文件,检查controlfile中的目录或文件是否真正在磁盘上

Delete backupset 24    24代表backupset 的编号, delete目录,也delete你的文件


注意:在做了alter databaseopen resetlogs;会把onlineredelog file清空,数据文件丢失.所以这个时候要做一个全备份。


resetlogs命令表示一个数据库逻辑生存期的结束和另一个数据库逻辑生存期的开始,每次使用resetlogs命令的时候,SCN不会被重置,不过oracle会重置日志序列号,而且会重置


联机重做日志内容.这样做是为了防止不完全恢复后日志序列会发生冲突(因为现有日志和数据文件间有了时间差)。


Rman 归档文件丢失导致不能备份的,在备份前先执行以下两条命令

crosscheck archivelog all;

delete expired archivelog all;


补充知识:RECOVER DATABASE UNTIL CANCEL RECOVER DATABASE UNTIL CANCEL USING BACKUP CONTROLFILE 区别


RECOVER DATABASE UNTIL CANCEL ==> DATAFILEHEADER SCN一定会小于CONTROLFILEDATAFILE SCN 如果你有进行RESTORE DATAFILE,则该RESTOREDATAFILE HEADERSCN一定会小于目前CONTROLFILEDATAFILE SCN,此时会无法开启数据库,必须进行mediarecovery重做archive log直到该datafile headerSCN=current scn


RECOVER DATABASE UNTIL CANCEL USING BACKUPCONTROLFILE; ==> DATAFILE HEADER SCN一定会大于CONTROLFILEDATAFILE SCN 如果只是某TABLEDROP掉,没有破坏数据库整体数据结构,还可以用NCOMPLETERECOVERY解决如果是某个TABLESPACE ORDATAFILEDROP掉,因为档案结构已经破坏,目前的CONTROLFILE内已经没有DATAFILE的信息,就算你只RESTORE DATAFILE然后进行INCOMPLETERECOVERY也无法救回被DROPDATA FILE只好RESOTRE 之前备份的CONTROLFILE(里头被DROPDATAFILE Metadata此时还存在),不过RESTOREC CONTROLFILE此时Oracle会发现CONTROL FILE内的SYSTEM SCN会小于目前的DATAFILE HEADERSCN,也不等于目前储存于LOGFILE内的SCN此时就必须使用RECOVER DATABASE UNTIL CANCEL USING BACKUPCONTROLFILEDROPDATAFILE OR DROP TABLESPACE之前的SCN


************* Scrip of RMAN *********************

Full backup


run {

allocate channel oem_backup_disk1 type disk format'G:\Full\%U';

backup incremental level 0 cumulative as BACKUPSETtag '%TAG' database include current controlfile;

backup as BACKUPSET tag '%TAG' archivelog all notbacked up;

release channel oem_backup_disk1;

}


Partial for Data file backup

run {

allocate channel oem_backup_disk1 type disk format'G:\partial\%U';

backup incremental level 0 cumulative as BACKUPSETtag '%TAG' datafile 'I:\ORACLE\PRODUCT\10.2.0\ORADATA\MSLTSD\SYSTEM01.DBF','I:\ORACLE\PRODUCT\10.2.0\ORADATA\MSLTSD\UNDOTBS01.DBF', 'I:\ORACLE\PRODUCT\10.2.0\ORADATA\MSLTSD\SYSAUX01.DBF','I:\ORACLE\PRODUCT\10.2.0\ORADATA\MSLTSD\USERS01.DBF'  include current controlfile;

backup as BACKUPSET tag '%TAG' archivelog all notbacked up;

release channel oem_backup_disk1;

}

allocate channel for maintenance type disk;

delete noprompt obsolete device type disk;

release channel;


Archive log file backup

run {

allocate channel oem_backup_disk1 type disk format'E:\OracleBackup\MSLTSD\ARCHIVELOG\%U';

backup as BACKUPSET tag '%TAG' archivelog all notbacked up 2 times;

delete noprompt archivelog until time 'sysdate - 2'backed up 2 times to device type disk;

releasechannel oem_backup_disk1;

}


你可能感兴趣的:(oracle,rman,详解与实例)