ORACLE各种文件常规恢复(最新整理)

1SPFILE丢失

2controlfile丢失

3UNDO恢复

4REDO恢复

5、非系统表空间恢复

6、数据文件恢复

7、非CATALOG恢复

8、基于时间点恢复

9、基于日志序列恢复

10、基于CATALOG数据恢复

11、使用增量备份的恢复操作

 

1SPFILE丢失:

startup nomount;

set dbid 3988862108;

restore spfile from autobackup;   ---从自动备份中还原

restore spfile from '/....'   ---如果找不到AUTO备份的路径,那么可以指定路径

shutdown immediate;

set dbid 3988862108;

startup;

      

    RMAN> RESTORE SPFILE TO '/tmp/spfileTEMP.ora' FROM AUTOBACKUP;   如果数据库在运行可以恢复到某个目录

 

模拟操作:

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)

 

 

2.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

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

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

 

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

resetlogs命令表示一个数据库逻辑生存期的结束和另一个数据库逻辑生存期的开始,每次使用resetlogs命令的时候,SCN不会被重置,不过oracle会重置日志序列号,而且会重置联机重做日志内容.这样做是为了防止不完全恢复后日志序列会发生冲突(因为现有日志和数据文件间有了时间差)。

*/

rman>recover database;  这里有可能出现控制文件过久的问题,那么就需要使用recover database using backup controlfile;

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;

 

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

using backup controlfile until cancel 区别

1. recover database using backup controlfile

2. recover database until cancel

3. recover database using backup controlfile until cancel;

4. recover database until cancel using backup controlfile;

区别:

1. 如果丢失丢失当前控制文件,用冷备份中的控制文件恢复的时候。用来告诉oracle,不要以controlfile中的scn作为恢复的终点;

2. 如果丢失current/active redo的时候。手动指定终点。

3. 如果丢失当前controlfile并且current/active redo都丢失,会先去自动应用归档日志,可以实现最大的恢复;

4. 如果丢失当前controlfile并且current/active redo都丢失,以旧的redo中的scn为恢复终点。因为没有应用归档日志,所有会丢失数据。

 

以下条件需要使用using backup controlfile

1)、使用备份控制文件(旧控制文件)

     2)、重建resetlogs控制文件,如果重建立noresetlogs不必要使用using backup controlfile

 

重建控制文件的时候:

使用noresetlogs方式创建的控制文件中scn是从redo log中获得;

    使用resetlogs方式创建的控制文件中scn是从datafile中获得。

 

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

 

3UNDO 损坏的情况

       Undo 的内容大多数是因为异常宕机,在启动的时候报的错误。DB 不能启动。

       比如:ORA-00600: internal error code, arguments: [4194],  

 

     对于Undo 损坏的情况,能用备份恢复最好,如果不能,就只能通过一些特殊的方法来恢复。

方法一: 使用system segment

1spfile 创建pfile然后修改参数

#*.undo_tablespace='UNDOTBS1'

#*.undo_management='AUTO'

#*.undo_tablespace 

#*.undo_retention

undo_management='MANUAL'

rollback_segments='SYSTEM'

 

2用修改之后的pfile重启DB

SQL> STARTUP MOUNT pfile='F:\initorcl.ora' ;

 

3)删除原来的表空间,创建新的UNDO 表空间

SQL> drop tablespace undotbs;

SQL> create undo tablespace undotbs1 datafile '/u01/oradata/undotbs1.dbf' size 10M;

 

4)关闭数据库,修改pfile参数,然后用新的pfile创建spfile,在正常启动数

据库。

*.undo_tablespace='UNDOTBS1'

*.undo_management='AUTO'

#undo_management='MANUAL'

#rollback_segments='SYSTEM'

 

方法二:跳过损坏的segment

  在方法一里面,我们使用了system segmentundo segment 有多个,我们可以通过alert  log 来查看正在使用的是哪些segment,这些段有可能损坏了。我们只需要把这些损坏的segment 跳过,先正常启动DB,在创建新的UNDO 表空间,在切换一下。

 

1)修改pfile,添加参数:

*._corrupted_rollback_segments='_SYSSMU11$','_SYSSMU12$','_SYSSMU13$'

 

这些字段的值,我们通过alert log 查看。也可以通过如下命令查看:

#strings system01.dbf | grep _SYSSMU | cut -d $ -f 1 | sort -u

 

2)用修改之后的pfile启动DB

  因为跳过了哪些损坏的segment,所以DB 可以正常启动。

3)创建新的UNDO 表空间,并切换过来

 

SQL> create undo tablespace undotbs1 datafile '/u01/oradata/undotbs1.dbf' size 10M;

SQL> alter system set undo_tablespace=undotbs1;

SQL> drop tablespace undotbs;

 

4修改pfile创建spfile并正常启动

删除

*._corrupted_rollback_segments='_SYSSMU11$','_SYSSMU12$','_SYSSMU13$'

 以上就是UNDO 出现故障的2种处理方法。

 

4Redo Log File损坏 (非全部丢失)

       重做日志文件在数据库中是要求最高的组件,首先其对磁盘的IO要求极高,其次一旦CURRENT组发生故障,数据库会立即崩溃,并且100%会发生数据丢失,所以ORACLE建议至少每个组需要两个成员,并且在数据库运行过程中日志文件会一直被锁定,以防不测。

 

Redo log的恢复分为两种:CURRENT CURRENT

 

CURRENT 情况

  造成redo 损坏,很多情况是与突然断电有关。这种情况下是比较麻烦的。

1)如果有归档和备份,可以用不完全恢复。

SQL>startup mount;

SQL>recover database until cancel; 先选择auto,尽量恢复可以利用的归档日志,

然后重新执行:

SQL>recover database until cancel; 这次输入cancel,完成不完全恢复,

resetlogs打开数据:

SQL>alter database open resetlogs打开数据库

 

2)强制恢复,这种方法可能会导致数据不一致

sql>startup mount;

sql>alter system set "_allow_resetlogs_corruption"=true scope=spfile;

sql>recover database until cancel;

sql>alter database open resetlogs;

这里主要看2点:

1)使用了_allow_resetlogs_corruption 参数

2)这种情况下,可能会报ORA-600[2662]SCN有关)和 ORA-600[4000](回滚段有关)的错误。

 

   使用_allow_resetlogs_corruption参数,强制的打开数据库,可能会导致逻辑的坏块,从而影响数据字典。  所以,即使使用该参数正常打开后,也需要做的一个操作:逻辑导出数据。重建实例,导入实例。消除逻辑坏块的可能性。

   运气好的话,数据库能正常打开,如果使用_allow_resetlogs_corruption参数启动报了undo  segment的错误而无法启动,处理方法参考undo 的处理情况。 

   但是由于使用_allow_resetlogs_corruption方式打开,会造成数据的丢失,且数据库的状态不一致。因此,这种情况下Oracle建议通过EXP方式导出数据库。重建新数据库后,再导入。

       metalink上的两篇文章介绍了两种情况的处理方法:

TECH: Summary For Forcing The  Database Open  With `_ALLOW_RESETLOGS_CORRUPTION` with Automatic Undo Management[ID 283945.1]

http://blog.csdn.net/tianlesoftware/archive/2010/12/29/6106083.aspx

ORA-600 [2662] Block SCN is ahead of Current SCN [ID 28929.1]

http://blog.csdn.net/tianlesoftware/archive/2010/12/29/6106130.aspx

 

CURRENT 情况

  这种情况下的恢复比较简单,因为redo log 是已经完成归档或者正在归档。没有正在使用。可以通过v$log 查看redo log 的状态。 

 

1)如果STATUSINACTIVE,则表示已经完成了归档,直接清除掉这个redo

log即可。

 

SQL>startup mount;

SQL> alter database clear logfile group 3 ; 

SQL>alter database open;

 

2如果STATUS ACTIVE 表示正在归档此时需要使用如下语句

SQL>startup mount;

SQL> alter database clear unarchived logfile group 3 ; 

SQL>alter database open;

 

5、非系统表空间

       若出现介质故障导致某表空间不可用恢复可以在数据库处于  open mount 状态下进行步骤如下

1.  将该表空间置于offline状态

2.  修复表空间数据

3.  恢复表空间并处于一致性

4.  将表空间online

rman> sql 'alter tablespace dave offline';

如果文件不存在,就加immediate 参数

rman> sql 'alter tablespace dave offline immediate';

rman>restore tablespace dave;

rman>recovery tablespace dave;

rman>sql 'alter tablespace dave online';

 

6、数据文件损坏

  如果出现介质故障导致某表空间数据文件丢失(这种情况也可以参照表空间损坏的恢复)。

恢复可以在数据库处于 open mount 状态下进行,只需4个步骤

1.  将该数据文件置于 offline 状态

2.  修复数据文件(指定数据文件编号)

3.  恢复数据文件

4.  将数据文件 online

 

rman> sql 'alter datafile 8 offline ';

rman>restore datafile 8;

rman>recovery datafile 8;

rman>sql 'alter datafile 8 online';

 

7、非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操作的,那么如何在这种情况下操作呢

直接添加隐含参数alter system set "_allow_resetlogs_corruption"='TRUE' scope=spfile;到最后要去掉隐含参数

alter system reset "_allow_resetlogs_corruption scope=spfile sid='*';

或者用下面的办法

SQL>create pfile from spfile;

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

*.allow_resetlogs_corruption='TRUE'; //容许resetlog corruption

SQL>shutdown immediate;

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

SQL>alter database open resetlogs;

 

8、基于时间点的恢复:

 run{

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

  restore database;

  recover database;

  alter database open resetlogs;

}

 

ALTER SESSION SET NLS_DATE_FORMAT='YYYY-MM-DD HH24: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;

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

基于 SCN的恢复:

1.startup mount;

2.restore database until scn 10000;

3.recover database until scn 10000;

4.alter database open resetlogs;

 

9、基于日志序列的恢复:

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

 

10RMAN 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 default tablespace rman_ts quota unlimited on rman_ts;

SQL>grant recovery_catalog_owner to rman;(grant connect 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 database open resetlogs;会把online redelog file清空,数据文件丢失.所以这个时候要做一个全备份。

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

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

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

crosscheck archivelog all;

delete expired archivelog all;

 

11、使用增量备份的恢复操作

       Oracle 会在还原数据文件时自动判断是否使用了增量备份策略,还会根据需要自动应用所需的增量备份集。在这种情况下,不需要执行不同的恢复操作。

       使用增量备份的还原操作期间,restore 命令只还原基本备份。一旦完成了这个还原操作,就可以执行recover 命令将增量备份和归档的重做日志应用于数据库。一旦完成了恢复操作,我们就能正常打开数据库。在所有情况下,Oracle 都会尝试还原基本备份和最新的增量备份。这样减少完全恢复数据库所应用的重做日志,从而减少还原时间。

       需要注意的是,由于在恢复进程期间,数据库很可能有多个备份集,所以恢复操作的时间会超出我们的预期。不过,根据多种因素,数据更改速率是一个重要因素,应用增量备份集比应用大量重做日志更快,这种增量备份解决方案就是一个快速的解决方案。因此,增量备份地优势在于它是一个快速备份的策略并且需要更小的空间来保存备份集片不过它的代价就是恢复时间有可能会更长。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值