阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Data Guard高级应用:通过闪回恢复failover备库

155次阅读
没有评论

共计 3894 个字符,预计需要花费 10 分钟才能阅读完成。

今天看到有一个网友提了一个问题,描述很简短

测试 DG 时,主库不能宕机,如何测试 failover?

其实这个需求从业务层面来说是合理的,一个数据量很大的核心数据库,如果需要做灾难演练,就希望在备库上做一下演练工作,而这个演练其实又不想影响到目前的主库,而且又希望能够尽可能模拟真实的情况,我想这样对于运维部门来说是最具有考核力度,而对于开发业务部门来说是最受欢迎的,因为他们什么都不需要改动。

而从技术角度来看,似乎有一些地方需要考量,如果备库 Failover 为主库,那么这个主库肯定是可以进行读写操作的,如果把它再切回备库,数据一致性怎么保证,怎么能保证是从上次的断电开始恢复。如果可以做,那真是一大福利。

我们来看看 Oracle 提供的方式方法,两大法宝,switchover 和 Failover

Switchover 切换的核心脚本如下,

在备库执行,取消日志应用

    recover managed standby database cancel;
    在主库执行,切换角色
    Alter database commit to switchover to physical standby with session shutdown;
    而 Failover 的核心脚本则为:
    在备库执行
    alter database recover managed standby database finish force;
    alter database commit to switchover to primary;
如此来看,要实现上面的部分还是有一些难度。
今天反反复复测试了不下十多次,重建了很多次环境,总算在晚饭过后把这个问题顺利调试好了,虽然思路上是可行的,但是有一个地方总是卡在了下面的错误上。
ORA-19909: datafile 1 belongs to an orphan incarnation
ORA-01110: data file 1: ‘/U01/app/oracle/oradata/newtest2/system01.dbf’
明白了原委,解决起来全然不费功夫。
我们先讲讲思路,还是闪回,但是闪回的玩法有一些差别,和 reinstate 的方式有一些区别。假设是一主一备的环境,备库开启了闪回数据库功能。

我们不动原来的主库,把备库 Failover 为主库。

Data Guard 高级应用:通过闪回恢复 failover 备库

然后这个时候 Failover 的主库可读可写,当然最后还是要切换回备库接收归档,可以使用闪回,同时还需要切换角色,这个地方需要好好琢磨一番改怎么处理。

Data Guard 高级应用:通过闪回恢复 failover 备库

假设我们的数据库主库为 newtest2, 备库为 snewtest2
在备库 snewtest2 上开启闪回,在备库上 MRP 可以实时接受数据变化。
SQL> alter database open;
Database altered.

SQL> SQL> alter database flashback on;
Database altered.

得到一个参考的 SCN
SQL> select current_scn from v$database;
CURRENT_SCN
———–
    1765837
查看闪回数据库特性是打开的。
SQL> select flashback_on from v$database;
FLASHBACK_ON
————————————
YES

然后我们在备库上开始 failover
DGMGRL> DGMGRL> failover to snewtest2;
Performing failover NOW, please wait…
Failover succeeded, new primary is “snewtest2”
DGMGRL>
操作很快完成,我们查看备库此时的状态和角色
SQL> select open_mode,database_role    from v$database;
OPEN_MODE                                DATABASE_ROLE
—————————————- ——————————–
READ WRITE                              PRIMARY
当然这个步骤可以做一些读写操作之类的。
然后我们开始计划切回备库。
SQL> shutdown immediate

SQL> startup mount

然后开启闪回数据库,恢复到指定的 SCN, 这个时候要注意,此时还是主库。
SQL> flashback database to scn 1765837;           
Flashback complete.
我们需要切换为备库,这个时候切换的命令就是关键,不是使用 switchover 的方式。
SQL> alter database convert to physical standby;
Database altered.
当然这个时候数据库在 nomount 阶段,我们需要重启备库。
SQL> alter database mount;
alter database mount
*
ERROR at line 1:
ORA-00750: database has been previously mounted and dismounted

SQL> shutdown immediate
SQL> startup mount

重新配置一下 DG Broker 即可,可以设置 dg_broker_start=false, 停掉 dmon, 然后删掉 $ORACLE_HOME/dbs 下的 dr*newtest2.dat 的配置文件,重新配置 DG Broker 即可。
配置起来都是老套路。
简单配置后,DG Broker 的检查就正常了。
DGMGRL> DGMGRL> show configuration;
Configuration – dg_newtest2
  Protection Mode: MaxPerformance
  Databases:
    newtest2  – Primary database
    snewtest2 – Physical standby database
Fast-Start Failover: DISABLED
Configuration Status:
SUCCESS
DGMGRL>
对应的数据库日志中可以看到后台已经开始应用日志了。
RFS[2]: Assigned to RFS process 44981
RFS[2]: Selected log 5 for thread 1 sequence 48 dbid 795252212 branch 921251959
Tue Aug 30 21:32:01 2016
Archived Log entry 5 added for thread 1 sequence 48 ID 0x2f7352f8 dest 1:
Tue Aug 30 21:32:01 2016
Media Recovery Log /U01/app/oracle/fast_recovery_area/SNEWTEST2/archivelog/2016_08_30/o1_mf_1_48_cwc2pk57_.arc
Media Recovery Waiting for thread 1 sequence 49 (in transit)
Recovery of Online Redo Log: Thread 1 Group 4 Seq 49 Reading mem 0
  Mem# 0: /U01/app/oracle/fast_recovery_area/SNEWTEST2/onlinelog/o1_mf_4_cwc0lmr7_.log
    当实现这个看起来有些特殊的需求的时候,我真心内心充满了喜悦,也着实惊叹 Oracle 的闪回给备库带来了如此多的改进。

————————————– 分割线 ————————————–

Oracle Data Guard 重要配置参数 http://www.linuxidc.com/Linux/2013-08/88784.htm

基于同一主机配置 Oracle 11g Data Guard http://www.linuxidc.com/Linux/2013-08/88848.htm

探索 Oracle 之 11g DataGuard http://www.linuxidc.com/Linux/2013-08/88692.htm

Oracle Data Guard(RAC+DG) 归档删除策略及脚本 http://www.linuxidc.com/Linux/2013-07/87782.htm

Oracle Data Guard 的角色转换 http://www.linuxidc.com/Linux/2013-06/86190.htm

Oracle Data Guard 的日志 FAL gap 问题 http://www.linuxidc.com/Linux/2013-04/82561.htm

Oracle 11g Data Guard Error 16143 Heartbeat failed to connect to standby 处理方法 http://www.linuxidc.com/Linux/2013-03/82009.htm

————————————– 分割线 ————————————–

更多 Oracle 相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12

本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-09/134812.htm

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-22发表,共计3894字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中