无备份恢复各种场景的处理

[复制链接]
查看11 | 回复9 | 2014-4-5 19:53:18 | 显示全部楼层 |阅读模式
本帖最后由 guoyJoe 于 2013-3-26 21:14 编辑
1.恢复密码文件
orapwd file=$ORACLE_HOME/dbs/orapwocp password=oracle force=y ignorecase=y;
--注:普通用户的密码大小写是否区分由初始参数sec_case_sensitive_logon,不归密码文件处理

2.恢复参数文件
找alert_sid.log日志

3.无备份的控制文件
***场景1:在线日志无损的情况下的重建
rm -rf control*
shutdown abort;
startup nomount;
CREATE CONTROLFILE REUSE DATABASE "BXDB" NORESETLOGS...
reocver database;
alter database open;
ALTER TABLESPACE TEMP ADD TEMPFILE '/u01/app/oracle/oradata/bxdb/temp01.dbf' reuse;
***场景2:在线日志损坏的情况下的重建
shutdown immediate; --注这里要正常关闭数据库,否则会要求system做恢复???
rm -rf control*
rm -rfredo*
startup nomount;
CREATE CONTROLFILE REUSE DATABASE "BXDB" RESETLOGS...
recover database until cancel usingBACKUP CONTROLFILE;--RMAN>recover database until sequence 2;
alter database open resetlogs;
ALTER TABLESPACE TEMP ADD TEMPFILE '/u01/app/oracle/oradata/bxdb/temp01.dbf' reuse;
***场景3:具有只读数据文件情况下的重建
startup nomount;
CREATE CONTROLFILE REUSE DATABASE "BXDB" NORESETLOGS...
recover database;--recover database using backup controlfile;
alter database open; --alter database open resetlogs;
alter database rename file '/u01/app/oracle/product/11g/dbs/MISSING00005' to '/u01/app/oracle/oradata/bxdb/tp2.dbf';
alter tablespace tp12 online; --不能设数据文件在线(alter database datafile 7;)
ALTER TABLESPACE TEMP ADD TEMPFILE '/u01/app/oracle/oradata/ocp/temp01.dbf' reuse;
***场景4:使用控制文件快照恢复
cp /u01/app/oracle/product/11g/dbs/snapcf_ocp.f /u01/app/oracle/oradata/ocp/control01.ctl
cp /u01/app/oracle/product/11g/dbs/snapcf_ocp.f /u01/app/oracle/oradata/ocp/control02.ctl
cp /u01/app/oracle/product/11g/dbs/snapcf_ocp.f /u01/app/oracle/oradata/ocp/control03.ctl
startup mount;
recover database using backup controlfile; --RMAN>recover database;
alter database open resetlogs;

4.恢复数据文件
rm -rf tp5.dbf;
alter database datafile 8 offline;
alter database create datafile '/u01/app/oracle/oradata/ocp/tp12.dbf';
select * from t20;---报错没找到文件
recover datafile 8;
alter database datafile 8 online;

5.恢复临时文件
alter tablesapce temp add tempfile '/u01/app/oracle/oradata/oca/temp02.dbf' size 20M autoextend on;
alter tablesapce temp drop tempfile '/u01/app/oracle/oradata/oca/temp01.dbf';

6.恢复在线重做日志
***场景1:每个日志组有两个在线日志成员,1号组是其中一个redo01B.log损坏了
alter database drop logfile member '/u01/app/oracle/oradata/oca/redo01B.log';
alter database addlogfile member '/u01/app/oracle/oradata/oca/redo01B.log' to group 1;
***场景2:每个日志组有两个在线日志成员,1号组的所有日志(redo01A.log和redo01B.log)损坏了
alter database clear logfile group 1;
alter database clear unarchived logfile group 1;
***场景3:所有日志组全部损坏了
rm -rf redo*
shutdown immediate;
startup mount;
recover database until cancel;
alter database open resetlogs;


回复

使用道具 举报

千问 | 2014-4-5 19:53:18 | 显示全部楼层



回复

使用道具 举报

千问 | 2014-4-5 19:53:18 | 显示全部楼层
arron刘 发表于 2013-3-27 16:16
谢谢刘大师支持


回复

使用道具 举报

千问 | 2014-4-5 19:53:18 | 显示全部楼层
支持。
回复

使用道具 举报

千问 | 2014-4-5 19:53:18 | 显示全部楼层
turingbt 发表于 2013-3-27 17:29
支持。

欢迎一起讨论。。。


回复

使用道具 举报

千问 | 2014-4-5 19:53:18 | 显示全部楼层



回复

使用道具 举报

千问 | 2014-4-5 19:53:18 | 显示全部楼层
原创的不顶对不起GUO侠
回复

使用道具 举报

千问 | 2014-4-5 19:53:18 | 显示全部楼层
第6条第3点有可能不成功
回复

使用道具 举报

千问 | 2014-4-5 19:53:18 | 显示全部楼层
coloredice 发表于 2013-3-27 22:12
第6条第3点有可能不成功

为什么?
回复

使用道具 举报

千问 | 2014-4-5 19:53:18 | 显示全部楼层
coloredice 发表于 2013-3-27 22:12
第6条第3点有可能不成功

如果是先Restore,再Recover不完全恢复,只要备份在,就一定可以成功。是吧。


如果备份没了,哪就BBED吧,恢复神器。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

主题

0

回帖

4882万

积分

论坛元老

Rank: 8Rank: 8

积分
48824836
热门排行