文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

[RMAN]异机恢复实验

2024-04-02 19:55

关注

一、        准备工作


1.     环境设定

 

源库: IP 192.168.131.100   SID:orcl

目标库: IP 192.168.131.101 安装与源库相同版本数据库软件(不创建实例)

 

2.     准备工作

 

源库创建完整备份集(含控制文件、数据文件、归档文件)。

为简单起见,源库和目标库端目录结构保持一致。如果不一致,在恢复过程中则注意修改相关路径。

 

二、        实验实施

 

1.     主库进行备份

 

        RMAN> run{

                    sql 'alter system archive log current';

                    backup database format '/backup/dbfull_%d_%u_%s.bak' plus archivelog format       '                        ‘/archivelog/archfull_%d_%u_%s.bak';

                    backup current controlfile format '/backup/ctl_%d_%T_%s.bak';}

 

2.     复制源库 spfile 到目标端相同目录下

 

( 1 )源库进行复制

$ cd $ORACLE_HOME/dbs

$ scp spfileorcl.ora oracle@192.168.131.101:$ORACLE_HOME/dbs

( 2 )目标库修改 spfile

这一步不是必须的。

如果目标库与源库路径保持一致,则不需要进行任何修改。如果路径不一致的话,则需要保证以下路径正确:

n   Audit_file_dest : ORACLE 审计输出的 debug 日志路径

n   Control_files :控制文件路径

n   db_recovery_file_dest : FRA 路径(如果指定 FRA 的话)

n   log_archive_dest_1 :日志归档路径

 

注: spfile 是二进制文件,不能直接编辑。如果要修改,则需要通过 spfile 创建 pfile, 然后对 pfile 进行修改,再通过 pfile 创建 spfile 。

 

3.     目标库启动 nomount

 

$ export $ORACLE_SID=orcl

$ sqlplus / as sysdba

SQL> startup nomount

 

启动 nomount 状态需要 spfile 。如果源库的 spfile 没有放在 $ORACLE_HOME/dbs 目录下,则需要执行 :

SQL> startup nomount from spfile=’/url/spfileorcl.ora’;

 

4.     使用 RMAN 还原 controlfile

 

$ rman target /

RMAN> restore controlfile from '/backup/ctl_ORCL_20181022_31.bak';

      不管有几个控制文件,都会被恢复到相应路径下。

     

 

5.     开启数据库到 mount 状态

开启数据库到 mount 状态需要读取 controlfile

 

SQL> alter database mount;

 

6.     修复数据库

 

在这个环境中,源库和目标库的路径保持一致,因此这里可以直接用原路径修复。如果目标库与源库路径不同的话,则需要通过 SET NEWNAME FOR DATAFILE 命令来为数据文件重新设定路径(注意 SET NEWNAME 必须要放在 run 块中执行)。

 

RMAN> restore database;

     

此时,数据文件都已经修复到相应路径下

 

7.     恢复数据库

RMAN> recover database;

archived log thread=1 sequence=13

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

RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============

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

RMAN-03002: failure of recover command at 10/22/2018 03:39:24

RMAN-06054: media recovery requesting unknown archived log for thread 1 with sequence 13 and starting SCN of 1052433

这里的报错是正常的,因为我们创建的热备份是不一致备份,源库的归档过来了,但是 redo 日志没有随备份集过来,因此恢复数据库肯定恢复不到原来的状态。这个错误提示你想要继续恢复的话还需要线程 1 生成的 sequence13 的 redo log 。如果你要保持一致的话,必须复制源库的重做日志文件。

此时,数据库已经恢复完成了

 

8.     打开数据库

SQL> alter database open resetlogs;

 

 

 

-------------- end ------------------


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯