Oracle

Oracle学习笔记之RMAN备份(2)

日期:2015/6/28来源: IT猫扑网

  自动备份

  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.log cmdfile=bakl2

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

  root> service crond restart

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

  在非catalog模式下,备份的信息存储在controlfile文件中,如果controlfile文件发生毁坏,那么就不能能够进行恢复,使用在备份的时候需要把controlfile也进行自动备份

  Dbid=?

  . configure controlfile autobackup on;

  . Backup database plus archivelog delete input;

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

  RMAN> connect target /

  connected to target database: ORA10G (DBID=3988862108)

  这个Dbid=3988862108

  RMAN>show all;来查看参数

  using target database control file instead of recovery 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 DEVICE TYPE DISK TO '%F'; # default

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

  CONFIGURE DATAFILE BACKUP COPIES FOR DEVICE TYPE DISK TO 1; # default

  CONFIGURE ARCHIVELOG BACKUP COPIES FOR DEVICE TYPE DISK 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

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

  RMAN> configure controlfile autobackup on;

  RMAN> show all; //这样就能够发现controlfile 能够进行自动备份

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

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

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

  口令文件丢失(不属于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 processing system 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 dbid 3988862108)

  controlfile 丢失:

  startup nomount;

  restore controlfile from autobackup;

  alter database mount;

  recover database;

  alter database open resetlogs;

  注意:在做了alter database open resetlogs;会把online redelog 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 STACK FOLLOWS ===============

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

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

#p#副标题#e#

  ORA-01194: file 1 needs more recovery to be consistent

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

  //出错, redo log的scn记录在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 3 offline";

  2. restore datafile 3

  3. recover datafile 3

  4. sql "alter database datafile 3 online";

  表空间丢失:

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

  2. restore tablespace users;

  3. recover tablespace users; //与online redolog file 信息一致

  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 *;

<

相关文章

相关下载

网友评论

我要评论...
    没有更早的评论了
    取消