第6天-4 控制文件脚本】【增加redo log 镜像】【控制文件损坏下rman恢复】

Oracle控制文件与Redo日志管理
本文介绍Oracle数据库中控制文件与Redo日志的管理方法,包括控制文件的备份与恢复流程、Redo日志镜像的创建过程,并讨论了不同场景下使用NORESETLOGS与RESETLOGS的区别。
-6-4 控制文件脚本,增加redo log 镜像,控制文件损坏下rman恢复
--当前联机日志损害,不完全恢复,不完全恢复是针对全库了,scn要退就所有文件退,所有不完全恢复不能哪个文件坏就恢复哪个文件,
--所有文件scn都升高。
--完全恢复,哪个文件坏了恢复哪个

--备份控制文件,路径必须是存在的路径,否则发生ORA-27040: 文件创建错误, 无法创建文件
SQL> alter database backup controlfile to 'C:\oracle\product\10.2.0\flash_recovery_area\2013-11-4\ctl.ctl';
--生成控制文件创建脚本
SQL> alter database backup controlfile to trace as 'C:\oracle\product\10.2.0\flash_recovery_area\2013-11-4\ctl.txt';

--控制文件脚本包含两种
1.NORESETLOGS
2.RESETLOGS

--当联机重做日志没有损坏用包含NORESETLOGS的创建脚本
STARTUP NOMOUNT
CREATE CONTROLFILE REUSE DATABASE "TEST" NORESETLOGS  ARCHIVELOG
--当联机重做日志损坏用包含RESETLOGS的创建脚本
STARTUP NOMOUNT
CREATE CONTROLFILE REUSE DATABASE "TEST" RESETLOGS  ARCHIVELOG

--也可以指定生成包含NORESETLOGS或者RESETLOGS的控制文件创建脚本
SQL> alter database backup controlfile to 'C:\oracle\product\10.2.0\flash_recovery_area\2013-11-4\ctl.ctl' resetlogs;
SQL> alter database backup controlfile to 'C:\oracle\product\10.2.0\flash_recovery_area\2013-11-4\ctl.ctl' noresetlogs;

SQL> col member format a40;            --a表示字符长度为40,格式化下面member长度

--增加redo log的镜像
--添加镜像之前
SQL> select * from v$logfile;
    GROUP# STATUS  TYPE    MEMBER                                   IS_
---------- ------- ------- ---------------------------------------- ---
         4         ONLINE  C:\ORADATA\TEST\AUTOLOG\REDO04.LOG       NO
         5         ONLINE  C:\ORADATA\TEST\AUTOLOG\REDO05.LOG       NO
         6         ONLINE  C:\ORADATA\TEST\AUTOLOG\REDO06.LOG       NO

--添加镜像
SQL> alter database add logfile member 'C:\oradata\test\autolog_jingxiang\redo04.log' to group 4;

数据库已更改。

SQL> alter database add logfile member 'C:\oradata\test\autolog_jingxiang\redo05.log' to group 5;

数据库已更改。

SQL> alter database add logfile member 'C:\oradata\test\autolog_jingxiang\redo06.log' to group 6;

--添加后
SQL> select * from v$logfile;
    GROUP# STATUS  TYPE    MEMBER                                             IS_
---------- ------- ------- -------------------------------------------------- ---
         4 INVALID ONLINE  C:\ORADATA\TEST\AUTOLOG_JINGXIANG\REDO04.LOG       NO
         4         ONLINE  C:\ORADATA\TEST\AUTOLOG\REDO04.LOG                 NO
         5         ONLINE  C:\ORADATA\TEST\AUTOLOG\REDO05.LOG                 NO
         6         ONLINE  C:\ORADATA\TEST\AUTOLOG\REDO06.LOG                 NO
         5 INVALID ONLINE  C:\ORADATA\TEST\AUTOLOG_JINGXIANG\REDO05.LOG       NO
         6 INVALID ONLINE  C:\ORADATA\TEST\AUTOLOG_JINGXIANG\REDO06.LOG       NO
   
--控制文件创建脚本
--查询控制文件的各种信息
select * from v$controlfile_record_section

--==
--以下视图区别
select * from v$archived_log   --归档就会记录
--
select * from v$log_history    --日志一旦切换就是记录,归档非归档日志都会切换,都会有记录


--==模拟控制文件损坏,用rman恢复
--注意要平时要保存日志,记录dbid,连接RMAN会提示dbid
RMAN>set dbid=1288691788       --解决catalog由多个实例公用,target 模糊的问题
SQL> show parameter control_files  --nomount下查到,说明参数文件中有关于控制文件位置的记录

S1.C:\>rman target sys/system@jingtai1 catalog rman/rman@rman
S2.RMAN> list backup of controlfile;   --查看控制文件备份
S3.RMAN> restore controlfile;
S4.RMAN> alter database mount;

SQL> select file#,checkpoint_change# from v$datafile;
     FILE# CHECKPOINT_CHANGE#
---------- ------------------
         1            2181683
         2            2181683
         3            2181683
         4            2181683
         5            2181683
         6            2181683
         7            2181683
         8            2181683
         9            2181683
        10            2181683
        11            2181683
SQL> select file#,checkpoint_change# from v$datafile_header;
     FILE# CHECKPOINT_CHANGE#
---------- ------------------
         1            2189534
         2            2189534
         3            2189534
         4            2189534
         5            2189534
         6            2189534
         7            2189534
         8            2189534
         9            2189534
        10            2189534
        11            2189534
S5.SQL> recover database using backup controlfile;       --恢复的最后报O/S-Error: (OS 2) 系统找不到指定的文件。
   SQL> auto
S6.SQL> recover database using backup controlfile;
   SQL> C:\oradata\test\autolog\redo04.log               --输入最后一次未归档日志路径及文件
S7.SQL> alter database open resetlogs;

--S5恢复的最后报O/S-Error: (OS 2) 系统找不到指定的文件的原因
1.恢复终点=不一致的数据文件+归档日志+为归档的联机重做日志;
oracle恢复利用归档日志,但是最后理论上的最后一个归档日志还没有归档也就是未归档的联机重做日志;
因此S到用归档日志恢复的阶段最后一个归档日志会找不到文件,S6输入最后一次为归档拦击重做日志,就是因为该文件里面的内容就是
oracle要找的用归档日志恢复的阶段最后一个归档日志的内容。
oracle恢复是在不一致的数据文件基础上用归档日志。DBA手动把联机重做日志当成归档日志输入给oracle。

--==
思考用控制文件创建脚本的区别?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值