前段时间一个亿级分区表,被分割成历史表和业务表,历史表中保留15天以外的数据,每天都会从业务表中的15天外的数据copy到历史表,并删除业务表15天外的数据,逻辑也很简单,但插入历史表的where 条件写的不是对,导致数据没插入,每天还从业务表中删除了。总之丢失了10天的业务历史数据,不巧的是客户突然要历史数据,呵呵。。祸不单行;

好了废话不多说,切入正题,rac 使用NBU netbackup 对数据库备份的,周日全备周一到周六增量

源主机HostA,目标主机HostB,NBUMaster主机nbuserver,Oracle_sid均为test,Oracle用户均为oracle。两台主机的操作系统、数据库版本、NBU软件版本一致。

1、增加nbuserver主机上文件

新建一个空文件,取消nbu的异机恢复限制

[nbuserver:root]# touch /usr/openv/netbackup/db/altnames/No.Restrictions

2、编辑完后需要重启netbackup

[nbuserver:root]# /usr/openv/netbackup/bin/bp.kill_all

[nbuserver:root]# /usr/openv/netbackup/bin/bp.start_all

下面开始恢复步骤(均为oracle用户操作)

3、copy spfile

在HostA上test数据库的pfile(create
pfile from spfile)copy至HostB中的$ORACLE_HOME/dbs目录下,因为源库是rac
节点,所以pfile copy到目标主机后还需要修改一下参数配置,把集群相关的配置删除

[HostA:ora]# ll $ORACLE_HOME/dbs/inittest.ora

4、HostB上,密码文件、相应的dump目录

[HostB:ora]#orapwd file=<fname> password=<password>entries=<users>

[HostB:ora]#mkdir $admin/test/*dump

5、启动数据库至nomount

[HostB:ora]# sqlplus '/as sysdba'

SQL> startup nomount

6、进行rman恢复

[HostB:ora]# rman target /

7、set dbid(HostA上test库的dbid)

RMAN> set dbid=1203153859

executing command: SET DBID

database name is "TEST" and DBID is 2091611406

查看HostA上的dbid

SQL> select dbid from v$database;

8、恢复control file

[HostB:ora]# /usr/openv/netbackup/bin/bplist -S 'nbuserver' -C 'HostA' -t 4 -R -l /

#查看nbuserver上的备份列表

 查找周日的全备的控制文件

RMAN>RUN {

2> allocate channel D1 type 'sbt_tape' parms 'SBT_LIBRARY=/usr/openv/netbackup/bin/libobk.so64';

3> send 'NB_ORA_SERV=nbuserver,NB_ORA_CLIENT=HostA';

4> RESTORE CONTROLFILE FROM 'cntrl_39324_1_784448328';

5> RELEASE CHANNEL D1;

6> }

9、控制文件修复成功,将库alter至mount状态

SQL> alter database mount;

database mounted

10、恢复数据库

RMAN> run {

2> allocate channel D1 type 'sbt_tape' parms 'SBT_LIBRARY=/usr/openv/netbackup/bin/libobk.so64';

3> send 'NB_ORA_SERV=nbuserver,NB_ORA_CLIENT=HostA';

4> set until time '2017-07-01 00:00:00';

5> restore database;

6> recover database;

7> RELEASE CHANNEL D1;

8> }

11、恢复归档日志

sql>select file#,checkpoint_change# from v$datafile;

sql>select file#,checkpoint_change# from v$datafile_header;

sql>select checkpoint_change# from v$database;

查看当前文件的snc和系统snc不一致,需要日志文件恢复

sql>recover database using backup controlfile until time '2017-07-01 00:00:00';

会提示需要的日志

rman>RUN {

1>allocate channel D1 type 'sbt_tape' parms 'SBT_LIBRARY=/usr/openv/netbackup/bin/libobk.so64';
2>send 'NB_ORA_SERV=hb-manage-backup,NB_ORA_CLIENT=proddb-2';

3>restore archivelog from logseq 55459 thread 1;

4>RELEASE CHANNEL D1;

5>}

根据需要的日志点提示,再从NBU上恢复归档日志文件

恢复成功后继续介质恢复

sql>recover database using backup controlfile until time '2017-07-01 00:00:00';

会提示需要的归档日志  auto 就行

 

12、打开数据库

SQL>
alterdatabase open resetlogs;

 

NBU Rman异机恢复Oracle的更多相关文章

  1. Oracle 单实例 迁移到 RAC 实例 -- 使用RMAN 异机恢复

    Oracle 官网有关单实例迁移到RAC的一个步骤说明: How to Convert 10g Single-Instance database to 10g RAC using Manual Con ...

  2. Linux平台下RMAN异机恢复总结

    下面总结.整理一下RMAN异机恢复这方面的知识点,这篇笔记在个人笔记里面躺了几年了,直到最近偶然被翻看到,遂整理.总结一下.如下所示,个人将整个RMAN异机恢复分为准备工作和操作步骤两大部分.当然,准 ...

  3. RMAN异机恢复实验---转载

    一.RMAN异机恢复实验 2011年3月23日00:44 1.环境介绍: 主机1: 操作系统 REDHAT5.5 IP地址 172.16.1.120 主机名 sigle 数据库版本 10.2.0.4 ...

  4. Oracle12c RAC RMAN异机恢复

    ######################################################## #编辑pfile文件initspdb.ora vi /oracle/app/oracl ...

  5. oracle rman异机恢复

      Oracle源主机 Oracle目标主机 主机平台 CentOS6.2(final) CentOs6.2(FInal) 主机名 vick rman IP地址 192.168.1.11 192.16 ...

  6. RMAN异机恢复遭遇ORA-01547、ORA-01152、ORA-01110错误案例

    测试环境:     操作系统  :  Red Hat Enterprise Linux ES release 4 (Nahant Update 4)   VMWARE     数据库     :  O ...

  7. rman异机恢复,全部恢复和增量恢复

    1.首先准备工作:hostname 192.168.222.11 ol7.localdomain ol7建立相关目录:mkdir -p /u01/app/oracle/oradata/DB11G/mk ...

  8. RMAN异机恢复步骤及故障处理

    一.測试机安装OS+Oracle Software.包含配置oracle用户.组和环境变量(略) 二.開始异机恢复 1. 复制源库最新备份集.初始化參数.password文件到測试机 [oracle@ ...

  9. Oracle RMAN 异机恢复一例

    背景介绍:本例需求是将NBU备份的oracle数据库恢复到另一主机上. NBU环境配置.异机上的Oracle软件安装配置忽略,下面只介绍OracleDB恢复的过程. ----------------- ...

随机推荐

  1. 10276 - Hanoi Tower Troubles Again!(思维,模拟)

    People stopped moving discs from peg to peg after they know the number of steps needed to complete t ...

  2. Android埋点技术概览

    注:本文同步发布于微信公众号:stringwu的互联网杂谈Android无埋点技术概览 本文是Android无埋点系列的开篇---埋点技术概览 1 背景 埋点是数据产品经理(分析师)基于业务需求,对用 ...

  3. 4- MySQL创建表以及增删改查

    查看表结构 查看表的结构,使用命令:desc 表明: 创建表(命令) 格式:使用create table创建表,必须给出下列信息: 1.新表的名字. 2.表中列的名字和定义,用逗号隔开. 语法: cr ...

  4. php异常及错误信息捕获并记录日志实现方法全解析

    php异常处理 什么是异常? PHP 5 提供了一种新的面向对象的错误处理方法.异常处理用于在指定的错误(异常)情况发生时改变脚本的正常流程.这种情况称为异常. 当异常被触发时,通常会发生: 当前代码 ...

  5. RF-字符串拼接

    贪婪截取(abcABC123edf123,左边截取abc,右边截取123,得到ABC123edf) 截取字符串 [Arguments] ${string} ${left} ${right} ${str ...

  6. 【python】Leetcode每日一题-笨阶乘

    [python]Leetcode每日一题-笨阶乘 [题目描述] 通常,正整数 n 的阶乘是所有小于或等于 n 的正整数的乘积.例如,factorial(10) = 10 * 9 * 8 * 7 * 6 ...

  7. 在AWS Glue中使用Apache Hudi

    1. Glue与Hudi简介 AWS Glue AWS Glue是Amazon Web Services(AWS)云平台推出的一款无服务器(Serverless)的大数据分析服务.对于不了解该产品的读 ...

  8. IDEA安装插件时搜索不到,一直在转圈刷新,无法安装

    方法一:更换一个网络(我自己没有测试过) 参考链接:https://blog.csdn.net/m0_37856386/article/details/110389028 方法二:打开settings ...

  9. 01 CTF MISC 杂项 知识梳理

    1.隐写术( steganograhy ) 将信息隐藏到信息载体,不让计划的接收者之外的人获取信息.近几年来,隐写术领域已经成为了信息安全的焦点.因为每个Web站点都依赖多媒体,如音频.视频和图像.隐 ...

  10. 高阶函数 / abs方法

    abs()求绝对值,填括号里面