1、先查找备库控制文件路径

先在备库上找出控制文件的路径,通过和主库一样,不过为了以防万一,还是check为好。

SQL>  select name from v$controlfile;

NAME

--------------------------------------------------------------------------------

/Oracle/app/oracle/oradata/powerdes/control01.ctl

/oracle/app/oracle/fast_recovery/powerdes/control02.ctl

SQL>

2、准备控制文件备份文件

在主库上备份当前的控制文件,记得生成的备份文件要在执行全备之前生成,而且命令行也是带for standby字样的backup current controlfile for standby format'/home/oracle/ctlfile.bak'才行,也可以手动提前生成。

RMAN> backup current controlfile for standby format '/home/oracle/ctlfile.bak';

Starting backup at 2016-11-23 21:20:41

using channel ORA_DISK_1

channel ORA_DISK_1: starting full datafile backup set

channel ORA_DISK_1: specifying datafile(s) in backup set

including standby control file in backup set

channel ORA_DISK_1: starting piece 1 at 2016-11-23 21:20:42

channel ORA_DISK_1: finished piece 1 at 2016-11-23 21:20:43

piece handle=/home/oracle/ctlfile.bak tag=TAG20161123T212041 comment=NONE

channel ORA_DISK_1: backup set complete, elapsed time: 00:00:01

Finished backup at 2016-11-23 21:20:43

RMAN>

然后等备份任务结束后,在主库上,将备份前生成的控制文件、最近的一份备份文件到备库的相同目录:

scp /oracle/app/oracle/oradata/powerdes/control01.ctl 192.168.3.112:/home/oracle/

scp -r /data/backup/data/2016-11-23 192.168.3.112:/home/oracle/

3、检查主库备库环境

获取备库的tns:(我的是earth_m2)

cat $ORACLE_HOME/network/admin/tnsnames.ora

earth_m2 =

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.3.112)(PORT = 1521))

)

(CONNECT_DATA =

(SERVICE_NAME = powerdes)

)

)

(1)查看主库备库SID名字是否统一,这个很重要

# 备库:

[oracle@t1_dbm1_3_112 data]$  echo $ORACLE_SID

powerdes

[oracle@t1_dbm1_3_112 data]$

# 主库:

[oracle@t1_dbm1_3_111 ~]$  echo $ORACLE_SID

powerdes

[oracle@t1_dbm1_3_111 ~]$

(2)查看主库备份传输密码是否一致:

# 备库:

[oracle@t1_dbm1_3_112 dbs]$ cd $ORACLE_HOME/dbs

[oracle@t1_dbm1_3_112 dbs]$  strings orapwpowerdes

]\[Z

ORACLE Remote Password file

INTERNAL

89F7167638478F13

0Cv#

B6E56CBCA47429E2

[oracle@t1_dbm1_3_112 dbs]$

# 主库:

[oracle@t1_dbm1_3_111 ~]$ cd $ORACLE_HOME/dbs

[oracle@t1_dbm1_3_111 dbs]$ strings orapwpowerdes

]\[Z

ORACLE Remote Password file

INTERNAL

89F7167638478F13

0Cv#

B6E56CBCA47429E2

[oracle@t1_dbm1_3_111 dbs]$

4、启动备库到nomount状态

在备库上,直接copy覆盖控制文件

cp /home/oracle/ctlfile.bak /oracle/app/oracle/oradata/powerdes/control01.ctl

cp /home/oracle/ctlfile.bak /oracle/app/oracle/fast_recovery/powerdes/control02.ctl

然后启动到nomount状态

SQL> startup nomount

ORACLE instance started.

Total System Global Area 8551575552 bytes

Fixed Size              2270360 bytes

Variable Size              7247760232 bytes

Database Buffers    1291845632 bytes

Redo Buffers                 9699328 bytes

SQL>

5、使用duplicate恢复备库

在主库上,使用rman登录远程备库earth_m2

[oracle@t1_dbm1_3_111 ~]$ rlwrap rman target / auxiliary sys/04181123@earth_m2

Recovery Manager: Release 11.2.0.4.0 - Production on Wed Nov 23 20:05:54 2016

Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.

connected to target database: POWERDES (DBID=3481287162)

connected to auxiliary database: POWERDES (not mounted)

RMAN>

在rman命令行里面执行恢复命令:

run {
allocate auxiliary channel c1 devicetype disk;
allocate auxiliary channel c2 devicetype disk;
duplicate target database for standbynofilenamecheck dorecover;
release channel c1;
release channel c2;
}
#nofilenamecheck:必须指定NOFILENAMECHECK参数,避免覆盖primary数据库的当前的数据文件。另外主从路径一致,不需要执行文件路径以及check了
#release :这是关闭 前两行开启的通道

执行过程比较漫长,屏幕滚动信息比较多,这里不贴出来了,省略过……

执行命令后,需要很长时间,需要等待,因为需要写入文件到备库的数据文件目录里面,找个时候,在备库的alert log后台有如下记录日志,表明正在写数据文件:

Full restore complete of datafile 4 /oracle/app/oracle/oradata/powerdes/users01.dbf.  Elapsed time: 0:00:00

checkpoint is 32945676

last deallocation scn is 3

Wed Nov 23 20:14:42 2016

Full restore complete of datafile 3 /oracle/app/oracle/oradata/powerdes/undotbs01.dbf.  Elapsed time: 0:00:05

checkpoint is 32945676

last deallocation scn is 32897307

Undo Optimization current scn is 32934775

Wed Nov 23 20:15:50 2016

Full restore complete of datafile 5 /oracle/app/oracle/oradata/powerdes/example01.dbf.  Elapsed time: 0:01:18

checkpoint is 32945676

last deallocation scn is 32806636

…………

6、ORA-01152:问题

最后rman命令行里面duplicate命令执行完,窗口界面上有如下报错信息:

Signalling error 1152 for datafile 1!

Errors in file /oracle/app/oracle/diag/rdbms/earth_m2/powerdes/trace/powerdes_pr00_4069.trc:

ORA-01547: warning: RECOVER succeeded but OPEN RESETLOGS would get error below

ORA-01152: file 1 was not restored from a sufficiently old backup

ORA-01110: data file 1: '/oracle/app/oracle/oradata/powerdes/system01.dbf'

ORA-1547 signalled during: alter database recover cancel...

^C

有报错没有关系,接下来直接开始应用日志,启动归档日志传输,通过应用归档日志来保证主备数据的一致性:

# 先开始启动传输开始应用日志

SQL> alter database recover managed standby database using current logfile disconnect from session;

Database altered.

SQL># 实时观察应用日志状态

SQL> select sequence#,applied from v$archived_log order by sequence# asc;

……

SEQUENCE# APPLIED

---------- ---------

2334 YES

2335 YES

2301 rows selected.

SQL> # 等观察应用日志结束后,退出日志传输

SQL> alter database recover managed standby database cancel;

Database altered.

SQL> # 将备库从mount启动到open状态

SQL> alter database open;

Database altered.

SQL> # 查看备库状态,就会变成READ ONLY

SQL> select database_role,open_mode from v$database;

DATABASE_ROLE     OPEN_MODE

---------------- --------------------

PHYSICAL STANDBY READ ONLY

SQL> # 然后再次启动日志应用

SQL> alter database recover managed standby database using current logfile disconnect from session;

Database altered.

SQL>  # 查看open_mode,有了READ ONLY WITH APPLY字样,OK

SQL> select database_role,open_mode from v$database;

DATABASE_ROLE     OPEN_MODE

---------------- --------------------

PHYSICAL STANDBY READ ONLY WITH APPLY

SQL>

至此,Data Guard备库修复完成,如果遇到了ORA-01152问题,不需要慌张,可以试试应用日志来恢复数据。

ORACLE 11g 用Duplicate恢复Data Guard 备库详细过程的更多相关文章

  1. oracle data guard备库备份恢复

    客户有套data guard环境,主库在阿里云上,备库在本地机房,现在想定期做备份,但是因为一些原因,备份阿里云上的主库实现会有些问题,所以只能备份本地的备库.目前需求就是测试备库的备份文件是否可以进 ...

  2. Oracle 11gR2 Database和Active Data Guard迁移案例

    客户一套核心系统由一台Oracle Database 11.2.0.3.4单机和一台Active Data Guard组成,分别运行在两台PC服务器上,Oracle Linux 5.8 x86_64b ...

  3. 【Oracle RAC】Linux系统Oracle11gR2 RAC安装配置详细过程V3.1(图文并茂)

    [Oracle RAC]Linux系统Oracle11gR2 RAC安装配置详细过程V3.1(图文并茂) 2 Oracle11gR2 RAC数据库安装准备工作2.1 安装环境介绍2.2 数据库安装软件 ...

  4. 怎样使用 RMAN 增量备份恢复 data guard log gap(日志断档)

    主库查询最小scn 信息: SQL> col current_scn for 999999999999999 SQL>  SELECT CURRENT_SCN FROM V$DATABAS ...

  5. 搭建DG(data guard),及搭建过程中遇到的一些小问题

    一.准备工作:主库:虚拟机名称host06 主机名:host06 IP:192.168.100.60 db_name&SID:ENMO  db_unique_name:PROD 存储:文件系统 ...

  6. Oracle 11G DataGuard生产环境又一次启动具体过程

     场景,重新启动数据库,不重新启动linux系统,所以不用考虑监听程序,#linux输入lsnrctl start1 数据库关闭1.1 关闭主库SHUTDOWN IMMEDIATE; SQL> ...

  7. Oracle 11g R2创建数据库之手工建库方式

    在之前的博文当中梳理了关于DBCA静默方式创建数据库的过程,本文就手工通过SQL*PLUS客户端采用CREATE DATABASE语句创建数据库.这种建库方式就是完全使用手工SQL语句创建数据库,通常 ...

  8. kingbaseES V8R6集群备份恢复案例之---备库作为repo主机执行物理备份

    ​ 案例说明: 此案例是在KingbaseES V8R6集群环境下,当主库磁盘空间不足时,执行sys_rman备份,将集群的备库节点作为repo主机,执行备份,并将备份存储在备库的磁盘空间. 集群架构 ...

  9. Oracle 11g 异机恢复参考文档

      原库 目标库 操作系统 CentOS 6.4 CentOS 6.4 主机名 sht-sgmhadoopnn-01 sht-sgmhadoopnn-02 IP 172.16.101.55 172.1 ...

随机推荐

  1. (转)Android学习笔记---SQLite介绍,以及使用Sqlite,进行数据库的创建,完成数据添删改查的理解

    原文:http://blog.csdn.net/lidew521/article/details/8655229 1.SQLite介绍:最大特点是,无数据类型;除了可以使用文件或SharedPrefe ...

  2. openstack 本地化

    研究了一下 openstack中的本地化:主要使用gettext模块: 其中本地化包括对一般字符串的本地化和log的本地化:   (1) _localedir = os.environ.get('es ...

  3. 面向连接的Socket Server的简单实现(简明易懂)

    一.基本原理 有时候我们需要实现一个公共的模块,需要对多个其他的模块提供服务,最常用的方式就是实现一个Socket Server,接受客户的请求,并返回给客户结果. 这经常涉及到如果管理多个连接及如何 ...

  4. 数据结构《9》----Threaded Binary Tree 线索二叉树

    对于任意一棵节点数为 n 的二叉树,NULL 指针的数目为  n+1 , 线索树就是利用这些 "浪费" 了的指针的数据结构. Definition: "A binary ...

  5. LeetCode----Copy List with Random Pointer 深度拷贝,浅度拷贝,Lazy拷贝解析

    题目:A linked list is given such that each node contains an additional random pointer which could poin ...

  6. Swift:函数和闭包

    函数 函数是一个完成独立任务的代码块,Swift中的函数不仅可以像C语言中的函数一样有函数的参数和返回值,而且还支持嵌套,并且有函数参数默认值.可变参数等. //定义一个函数,注意参数和返回值,如果没 ...

  7. HDU 4004

    http://acm.hdu.edu.cn/showproblem.php?pid=4004 题意:青蛙过长L的河,只能落在石头上,石头数量是n,给出n个坐标,至多跳m次,求在可以过河的条件下,青蛙跳 ...

  8. 关于IE条件注释(译)

    本文翻译自此篇文章.翻译纯属业余. 许多网站为了确保他们的站点能够在不同的浏览器上有不同的显示效果而使用特征检测,一些传统的网站使用其他技术,诸如在服务器或客户端上使用脚本去检测浏览器类型.在这里我们 ...

  9. C# Socket Server 收不到数据

    #/usr/bin/env python # -*- coding: utf- -*- # C# Socket Server 收不到数据 # 说明: # 最近在调Python通过Socket Clie ...

  10. LeetCode Combinations (DFS)

    题意: 产生从1-n的k个数的所有组合,按升序排列并返回. 思路: DFS一遍即可解决.注意升序. class Solution { public: vector<vector<int&g ...