Oracle RAC备份异机单实例恢复演练
本文只节选了操作方案的部分章节:
3. 操作步骤 3.1. 异机单实例Oracle数据库软件安装
在异机上进行单实例Oracle数据库软件安装。该步骤过程不再本文中重复描述,如果对安装过程存在疑问,可参考之前发布的《Oracle 11g R2数据库安装作业指导书》相关内容。注意:为了保障恢复的正确性,应该尽量保障该服务器上安装的数据库软件版本与Rac平台下的数据库版本一致(包括小版本)。
3.2. 在Rac环境下进行全库备份
在Rac环境下,通过RMAN数据库备份管理工具对数据库进行全库备份。具体操作流程可以参考如下:
Rman
RMAN>connect target
RMAN>连接到目标数据库: SCMIS (DBID=2125161875)
RMAN>backup database;
需要注意查看输出日志中备份文件输出的目录。
3.3. 将备份文件整体上传到单实例服务器
将备份出来的相关文件通过FTP软件上传到单实例服务器。(本例中存储的路径为:d:\rmandump\)
3.4. 修改新生成的initSCMIS.ora文件
将文件内容修改成符合我们单实例环境下的设置,本操作过程中修改前,修改后的文件展示如下,方便大家进行对比、理解。
修改前文件如下:
scmis2.__db_cache_size=268435456
scmis1.__db_cache_size=402653184
scmis1.__java_pool_size=16777216
scmis2.__java_pool_size=16777216
scmis1.__large_pool_size=16777216
scmis2.__large_pool_size=16777216
scmis1.__oracle_base='C:\app\Administrator'#ORACLE_BASE set from environment
scmis2.__oracle_base='C:\app\Administrator'#ORACLE_BASE set from environment
scmis1.__pga_aggregate_target=704643072
scmis2.__pga_aggregate_target=704643072
scmis1.__sga_target=1023410176
scmis2.__sga_target=1023410176
scmis1.__shared_io_pool_size=0
scmis2.__shared_io_pool_size=0
scmis2.__shared_pool_size=704643072
scmis1.__shared_pool_size=570425344
scmis1.__streams_pool_size=0
scmis2.__streams_pool_size=0
*.audit_file_dest='C:\app\Administrator\admin\SCMIS\adump'
*.audit_trail='db'
*.cluster_database=true
*.compatible='11.2.0.0.0'
*.control_files='+ASMDISK/scmis/controlfile/current.261.813766611','+ASMDISK/scmis/controlfile/current.260.813766613'
*.db_block_size=8192
*.db_create_file_dest='+ASMDISK'
*.db_domain=''
*.db_name='SCMIS'
*.db_recovery_file_dest='+ASMDISK'
*.db_recovery_file_dest_size=10737418240
*.diagnostic_dest='C:\app\Administrator'
*.dispatchers='(PROTOCOL=TCP) (SERVICE=SCMISXDB)'
SCMIS2.instance_number=2
SCMIS1.instance_number=1
*.log_archive_format='ARC%S_%R.%T'
*.memory_target=1717567488
*.nls_language='SIMPLIFIED CHINESE'
*.nls_territory='CHINA'
*.open_cursors=300
*.processes=1000
*.recyclebin='ON'
*.remote_listener='SCAN:1521'
*.remote_login_passwordfile='exclusive'
*.sessions=1105
SCMIS2.thread=2
SCMIS1.thread=1
SCMIS2.undo_tablespace='UNDOTBS2'
SCMIS1.undo_tablespace='UNDOTBS1'
修改后文件如下:
*.audit_file_dest='d:\adump'
*.audit_trail='db'
*.compatible='11.2.0.0.0'
*.control_files='D:\ctl\CONTROL01.CTL','D:\ctl\CONTROL02.CTL'
*.db_block_size=8192
*.db_domain=''
*.db_name='SCMIS'
*.diagnostic_dest='d:\app\Administrator'
*.dispatchers='(PROTOCOL=TCP) (SERVICE=SCMISXDB)'
*.log_archive_dest_1='LOCATION=d:\arch'
*.log_archive_format='%t_%s_%r.dbf'
*.memory_target=1717567488
*.nls_language='SIMPLIFIED CHINESE'
*.nls_territory='CHINA'
*.open_cursors=300
*.processes=1000
*.remote_login_passwordfile='exclusive'
*.sessions=1105
*.undo_tablespace='UNDOTBS1'
注意内容:需要注意在参数文件中相关设置路径的参数,要保障服务器上存在相应的路径结构。
3.5. 将单实例服务启动到nomount状态
使用新的参数文件,将数据库启动到nomount状态。请注意确认使用新的参数文件启动,如果必要,可以在启动的指令中指定读取的文件路径以及文件名。
SQL> startup nomount;
3.6. 通过RMAN还原参数文件
通过RMAN工具,从备份中将参数文件还原到单实例服务器,示范指令如下:
RMAN> restore spfile to pfile 'd:\initSCMIS.ora' from 'd:\rmandump\ CF_SCMIS_7_1 ';
3.7. 将数据库启动到MOUNT状态
RMAN> mount database;
3.8. 将备份集注册进控制文件里
RMAN> catalog start with 'd:\rmandump\';
3.9. 确认数据文件、联机日志文件、临时文件路径
SQL> set pagesize 9999
SQL> col NAME for a65
SQL> select file#,name from v$datafile;
看到结果如下:
1 '+ASMDISK/scmis/onlinelog/group_1.262.813766617'
2 '+ASMDISK/scmis/onlinelog/group_1.263.813766619'
3 '+ASMDISK/scmis/onlinelog/group_2.264.813766621'
4 '+ASMDISK/scmis/onlinelog/group_2.265.813766625'
5 '+ASMDISK/scmis/onlinelog/group_3.268.813766997'
6 '+ASMDISK/scmis/onlinelog/group_3.269.813767001'
7 '+ASMDISK/scmis/onlinelog/group_4.270.813767003'
8 '+ASMDISK/scmis/onlinelog/group_4.271.813767007'
SQL> select name from v$tempfile;
+ASMDISK/scmis/tempfile/temp.261.781033565
3.10. 通过RMAN重命名数据文件和临时文件,进行还原
在RMAN下执行如下指令:
RUN {
SET NEWNAME FOR DATAFILE 1 to 'D:\datafile\system01.dbf';
SET NEWNAME FOR DATAFILE 2 to 'D:\datafile\sysaux01.dbf';
SET NEWNAME FOR DATAFILE 3 to 'D:\datafile\undotbs1.dbf';
SET NEWNAME FOR DATAFILE 4 to 'D:\datafile\users01.dbf';
SET NEWNAME FOR DATAFILE 5 to 'D:\datafile\undotbs2.dbf';
SET NEWNAME FOR DATAFILE 6 to 'D:\datafile\scmisx3_app01.dbf';
SET NEWNAME FOR DATAFILE 7 to 'D:\datafile\scmisx3_sys01.dbf';
SET NEWNAME FOR TEMPFILE 1 to 'D:\datafile\temp01.dbf';
RESTORE DATABASE;
SWITCH DATAFILE ALL;
SWITCH TEMPFILE ALL;
}
3.11. 修改联机日志文件的路径
在SQLPLUS下执行:
alter database rename file '+ASMDISK/scmis/onlinelog/group_1.262.813766617' to 'D:\redolog\redo1_1.log';
alter database rename file '+ASMDISK/scmis/onlinelog/group_1.263.813766619' to 'D:\redolog\redo1_2.log';
alter database rename file '+ASMDISK/scmis/onlinelog/group_2.264.813766621' to 'D:\redolog\redo2_1.log';
alter database rename file '+ASMDISK/scmis/onlinelog/group_2.265.813766625' to 'D:\redolog\redo2_2.log';
alter database rename file '+ASMDISK/scmis/onlinelog/group_3.268.813766997' to 'D:\redolog\redo3_1.log';
alter database rename file '+ASMDISK/scmis/onlinelog/group_3.269.813767001' to 'D:\redolog\redo3_2.log';
alter database rename file '+ASMDISK/scmis/onlinelog/group_4.270.813767003' to 'D:\redolog\redo4_1.log';
alter database rename file '+ASMDISK/scmis/onlinelog/group_4.271.813767007' to 'D:\redolog\redo4_2.log';
注意:以上每一行指令执行完成后都会被断开连接,只需要重新连接,继续逐行执行即可。
联机日志文件修改之后查看
SQL> set pagesize 9999
SQL> select member from v$logfile;
3.12. 恢复数据库
RMAN> recover database;
3.13. RESETLOGS打开数据库
SQL> alter database open resetlogs;
3.14. 恢复结果检查
到这里RAC到单实例备份恢复已经完毕,我们可以简单检查下
SQL> select thread#,status,enabled from v$thread;
THREAD# STATUS ENABLED
---------- ------------ ----------------
1 OPEN PUBLIC
2 CLOSED PUBLIC
SQL> select group#,thread#,archived,status from v$log;
GROUP# THREAD# ARCHIV STATUS
---------- ---------- ------ --------------------------------
1 1 1 YES INACTIVE
2 2 1 NO CURRENT
3 3 2 YES ACTIVE
4 4 2 YES UNUSED
SQL> archive log list;
数据库日志模式 存档模式
自动存档 启用
存档终点 d:\arch
最早的联机日志序列 3
下一个存档日志序列 4
当前日志序列 4
3.15. 抽查业务系统用户的数据
根据实际情况,使用业务系统所建立的用户,检查相关表空间,对象、数据的恢复情况。
Oracle RAC备份异机单实例恢复演练的更多相关文章
- 12c RAC 用Rman 恢复到异机单实例
准备工作 原服务器软件部署:Redhat 6.6 + Oracle 12.2.0.1 rac Oracle12c单实例安装 1.创建恢复服务器,设置大于原库数据大小的磁盘容量.设置相同的服务器主机名参 ...
- 使用不同用户对Oracle数据库进行异机恢复,失败,错误:Backup file not found in NetBackup catalog
最近做某数据库恢复演练,数据库版本是10.2.0.4,恢复控制文件一直报错,报错如下,经过反复折腾,原来恢复机上oracle用户不是oracle导致(我的是oraclev4),查看源库oracle用户 ...
- Oracle 11.2.0.4单实例打PSU,OJVM PSU补丁快速参考
写在前面: 1.Oracel打每个补丁的操作有时存在差异,所以不管多熟悉,都应该在打任何补丁之前阅读新补丁中附带的readme. 2.Oracle每季度都会更新一个最新的PSU,本文最新指的是当前最新 ...
- Asianux 7.3安装Oracle 11.2.0.4单实例体验
环境:Asianux 7.3 需求:安装Oracle 11.2.0.4 单实例 背景:系统使用默认的最小安装部署,Oracle安装额外需要的包统一使用yum安装. 查看当前系统相关信息: [root@ ...
- Linux平台Oracle 12.1.0.2 单实例安装部署
主题:Linux平台Oracle 12.1.0.2 单实例安装部署 环境:RHEL 6.5 + Oracle 12.1.0.2 需求:安装部署OEM 13.2需要Oracle 12.1.0.2版本作为 ...
- Oracle 11.2.0.4单实例打补丁
Oracle 11.2.0.4单实例打PSU,OJVM PSU补丁快速参考 写在前面: · 1.Oracel打每个补丁的操作有时存在差异,所以不管多熟悉,都应该在打任何补丁之前阅读新补 ...
- RMAN - 备份异机恢复
OS: Oracle Linux Server release 5.7 DB: Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - ...
- RMAN 备份异机恢复 并创建新DBID
测试平台信息: Oracle:11gR2 操作系统:Redhat 5.5 Target DB:dave 几点说明: (1)RMAN 异机恢复的时候,db_name必须相同. 如果说要想改成其他的实 ...
- Oracle - 通过dg,完成单实例到rac的迁移
一.概述 本文将介绍如何给单实例搭建一个rac dg,以及如何对其进行角色转换,完成从单实例到rac的迁移.预先具备的知识(rac搭建,单实例-单实例dg搭建) 二.实验环境介绍 主库(已有数据库实例 ...
随机推荐
- 读 Runtime 源码:对象与引用计数
以前只是看了很多博客,这次打算看一下源码,并记录下来.想到哪里就读到哪里,写到哪里.读的代码版本是:objc runtime 680,可以从这里下载 https://github.com/RetVal ...
- Android四大组件之服务-Service 原理和应用开发详解
一.Android 服务简介 Service是android 系统中的四大组件之一(Activity.Service.BroadcastReceiver.ContentProvider),它跟Acti ...
- SQL 编码规范
1. 必须对表起别名,方便调查表用了哪些列 比如 select owner,object_id,name from a,b where a.id=b.id; 如果不对表取别名,我怎么知道你访问的列是哪 ...
- Java安全防御学习笔记V1.0
Java安全防御学习笔记V1.0http://www.docin.com/p-766808938.html
- B/S的验证控件
验证控件 首先设置一下框架,设置为.net framework 4.0,在4.5下貌似会报错,设置方法为项目上右键/属性页/找到左侧菜单栏里的生成/将框架版本改为4.0. 一.非空验证:Require ...
- monkey检测内存泄漏
monkey中检查内存泄漏,实际上是对一个操作多次操作后看内存情况,内存泄漏具体的原理可百度,现在我们梳理检测内存泄漏的方法: 测试前你需要安装: 1.MAT分析工具 2.使用工具事实监控内存指标,现 ...
- 关于HTML5标签不兼容(IE6~8)
HTML5的语义化标签以及属性,可以让开发者非常方便地实现清晰的web页面布局,加上CSS3的效果渲染,快速建立丰富灵活的web页面显得非常简单. 比较常用的HTML5的新标签元素有: <hea ...
- JavaScript入门(9)
一.Math对象 Math对象,提供对数据的数学计算 使用Math的属性和方法,代码如下: <script type="text/javascript"> var my ...
- 预算oracle
select * from ( )) CODE_VERSION from ( SELECT tb_cube_fc05.pk_entity pk_org,/*主体pk*/ org_orgs.code o ...
- C#学习笔记1:正则表达式和数据库连接
1.using System.Text.RegularExpressions; 只有导入该命名空间,才能引入Regex对象,IsMatch是Regex中的一个方法,作用是来判断(输入)内容是否满足正则 ...