环境描述:

1.节点描述
节点 IP 节点描述
11.6.76.221 GG 抽取端 / DG 节点,数据库版本号为 Oracle-11.2.0.3,与 11.6.76.222 组成 DataGuard。
11.6.76.222 DG 节点,数据库版本号为 Oracle-11.2.0.3,与 11.6.76.221 组成 DataGuard。
192.168.87.221 GG 复制端,数据库版本号为 Oracle-11.2.0.4
2.拓扑结构

 
方案描述:
假设 11.6.76.221 最初为 DataGuard 主节点,则接下来通过描述 DataGuard 主备快速切换的完整过程,实现方案描述。
1.断开应用于数据库连接(GG抽取端 / DG 主库)
假设数据库配置了专门用于应用连接的 Service,且应用均通过 Service 连接数据库,则快速安全的操作步骤如下。
(1).停止应用系统;
(2).停止应用连接的 Service;
(3).Kill 应用会话;
(4).停止数据库计划作业
操作后,拓扑结构如下图所示。

2.禁用备库 Service(DG 备库)
停止备库 Service,防止 DataGuard 主备角色切换后,Service 自动启动。
注意:在 Service 启动的状态下,应用系统将能够连接数据库,而此时 GG 切换仍未完成,很可能造成数据丢失
3.检查 GG 抽取全部完成(GG 抽取端 / DG 主库)
随着数据库上应用连接的断开、定时作业的停止,此时数据库的数据处于静止状态
注意:倘若 DataGuard 切换的整个过程均能保证数据静止,那么 DG 切换后,只需重置 GG 抽取点即可实现 GG 快速切换。否则,直接基于 GG 官方方案切换,抽取进程需搜索 DG 切换点,其过程十分耗时,且难以实现自动化。具体参见《GoldenGate Installing and Configuring Oracle GoldenGate for Oracle Database》-11.6.4 Handling Role Changes In an ADG Configuration
因此,检查 GG 抽取全部完成是关键步骤,如下所示。
a.切换日志组
由于此时数据库已经处于静止状态,因此切换日志组后,最新日志组上并没有实际的 Redo 信息。因此倘若抽取进程已对最新日志组进行抽取,便可以确认 GG 抽取全部完成。
b.检查 GG 抽取进程当前 Seqno 状态
通过 GGSCI> info [process_name] 方式,检查 GG 抽取进程当前的 Seqno 状态。
假设切换后最新在线日志组 Sequence 号为 22753,则进程抽取 Seqno 也为 22753 时,则证明 GG 抽取全部完成。

4.DG 切换(GG 抽取端 / DG 主库、DG 备库)
进行 DataGuard 主备切换后,拓扑内各节点的状态如下。
节点 IP 节点状态
11.6.76.221 仍为 GG 抽取端,DataGuard 角色由 Primary -> Standby。由于角色发生了变化,因此将导致传统抽取模式下的抽取进程挂起,处于 Abend 状态。
11.6.76.222 DataGuard 角色由 Standby-> Primary。
192.168.87.221 仍为 GG 目标端。
主备切换后,拓扑结构如下所示。

5.切换 GG 抽取模式(GG 抽取端 / DG 现备库)
为保证 DG 角色切换后,传统抽取进程能正常对 Standby Redo 进行抽取,需要切换 GG 抽取模式为 ADG 模式。具体通过在抽取参数文件中新增如下参数。
TRANLOGOPTIONS MINEFROMACTIVEDG
注意:由于数据库处于静止状态,新增抽取参数后,可直接重置抽取点为当前,并重启进程,实现 GG 模块快速切换。操作步骤如下所示:
GGSCI> alter extract [process_name], tranlog, begin now
start [process_name]
例如:切换名为 EIVR 的 GG 抽取进程操作如下。
GGSCI> alter extract EIVR, tranlog, begin now
start EIVR
切换 GG 抽取模式后,拓扑结构如下所示。

6.启用并启动备库 Service(DG 现主库)
启用切换后 DG 主库 Service,并启动 Service 进程,准备应用接入。
7.重启应用
基于 DNS 解析,切换应用连接至 DG 切换后的主库。重启应用及数据库作业,完成完整切换
重启应用后,拓扑结构如下所示。

 
参考文档:
1.《GoldenGate 传统抽取进程的 ADG 模式》
2.《GoldenGate Installing and Configuring Oracle GoldenGate for Oracle Database》
      -11.6 Configuring Classic Capture in Oracle Active Data Guard Only Mode

html,body { font-size: 12pt }
body { font-family: Helvetica, "Hiragino Sans GB", "微软雅黑", "Microsoft YaHei UI", SimSun, SimHei, arial, sans-serif; line-height: 1.6; margin: 0 auto; padding: 1.25rem 1rem }
h1,h2,h3,h4,h5,h6 { margin: 1.25rem 0 0.625rem; padding: 0; font-weight: bold }
h1 { font-size: 1.67rem }
h2 { font-size: 1.5rem }
h3 { font-size: 1.25rem }
h4 { font-size: 1.17rem }
h5 { font-size: 1rem }
h6 { font-size: 1rem; color: #777777; margin: 1rem 0 }
div,p,ul,ol,dl,li { margin: 0 }
blockquote,table,pre,code { margin: 8px 0 }
ul,ol { padding-left: 2rem }
ol.wiz-list-level1>li { list-style-type: decimal }
ol.wiz-list-level2>li { list-style-type: lower-latin }
ol.wiz-list-level3>li { list-style-type: lower-roman }
blockquote { padding: 0 0.75rem }
blockquote>:first-child { margin-top: 0 }
blockquote>:last-child { margin-bottom: 0 }
img { border: 0; max-width: 100%; height: auto !important; margin: 2px 0 }
table { border-collapse: collapse; border: 1px solid #bbbbbb }
td,th { padding: 4px 8px; border-collapse: collapse; border: 1px solid #bbbbbb; min-height: 28px }
.wiz-hide { display: none !important }

GoldenGate 传统抽取进程随 DataGuard 主备快速切换的方案(ADG 模式)的更多相关文章

  1. GoldenGate 传统抽取进程的 ADG 模式

    :first-child { margin-top: 0; } blockquote > :last-child { margin-bottom: 0; } img { border: 0; m ...

  2. Oracle DataGuard主备切换(switchover)

    Oracle DataGuard主备切换可以使用传统的手动命令切换,也可以使用dgmgr切换,本文记录手动切换. (一)将主库切换为物理备库 STEP1:查看主库状态 SQL> SELECT O ...

  3. DataGuard主备归档存在gap的处理办法

    DataGuard主备之间可能由于网络等原因,造成备库和主库之间的归档日志不一致,这样就产生了gap. 解决gap的步骤: 1.在备库获得gap的详细信息 2.将需要的归档日志从主库拷贝到备库 3.备 ...

  4. Redis主备自动切换

    Sentinel(哨兵)是用于监控redis集群中Master状态的工具. 一.Sentinel作用  1.Master状态检测   2.如果Master异常,则会进行Master-Slave切换,将 ...

  5. KingbaseES R3 集群删除test库导致主备无法切换问题

    案例说明: 在KingbaseES R3集群中,kingbasecluster进程会通过test库访问,连接后台数据库服务测试:如果删除test数据库,导致后台数据库服务访问失败,在集群主备切换时,无 ...

  6. Mycat实现读写分离,主备热切换

    实验环境:ubutu server 14 Master IP:172.16.34.212 Slave IP:172.16.34.34.156 Mycat server IP:172.16.34.219 ...

  7. 物理DG主备库切换时遇到ORA-16139: media recovery required错误

    在物理DG主备库切换时遇到ORA-16139: media recovery required错误 SQL> ALTER DATABASE COMMIT TO SWITCHOVER TO PRI ...

  8. 云计算之路-阿里云上:RDS数据库连接数过万引发故障,主备库切换后恢复正常

    非常抱歉!今天 12:03-12:52 ,由于数据库连接数异常突增超过1万,达到了阿里云RDS的最大连接数限制,影响了全站的正常访问.由此给您带来麻烦,请您谅解. 在发现数据库连接数突增的问题后,我们 ...

  9. [terry笔记]11gR2_dataguard_主备库切换

    主备库切换  Switchover  一般SWITCHOVER切换都是计划中的切换,特点是在切换后,不会丢失任何的数据,而且这个过程是可逆的,整个DATA GUARD环境不会被破坏,原来DATA GU ...

随机推荐

  1. Block使用的简单总结

    一.Block简单的使用 1.block当作参数来传递 如下定义一个没有返回值无参数的block,并把它作为参数,让系统调用,注意:这里是系统在调用,不是我们调用 那么为什么需要把block当作参数去 ...

  2. 【vue系列之二】详解vue-cli 2.0配置文件

    上次给大家分享的是用vue-cli快速搭建vue项目,虽然很省时间和精力,但想要真正搞明白,我们还需要对其原理一探究竟. 大家拿到一个项目,要快速上手,正确的思路是这样的: 首先,如果在项目有read ...

  3. 使用C#系统服务定时执行操作

    1.新建项目 --> Windows 服务 2.Service1.cs代码 using System; using System.Collections.Generic; using Syste ...

  4. NPOI导出excel(带图片)

    近期项目中用到Excel导出功能,之前都是用普通的office组件导出的方法,今天尝试用下NPOI,故作此文以备日后查阅. 1.NPOI官网http://npoi.codeplex.com/,下载最新 ...

  5. 2017值得一瞥的JavaScript相关技术趋势

    2017值得一瞥的JavaScript相关技术趋势从属于笔者的Web 前端入门与工程实践,推荐阅读2016-我的前端之路:工具化与工程化获得更多关于2016年前端总结.本文主要内容翻译自,笔者对于每个 ...

  6. 【解决方案】Django管理页面无法显示静态文件

    [问题描述]:Django管理界面无法获取页面的css样式文件.图片等静态文件.调试模式下看到静态url显示404. [问题原因]:跟踪源码可以发现,静态文件的url是由Django自带的app(dj ...

  7. 设计模式之visitor模式,人人能懂的有趣实例

    设计模式,现在在网上随便搜都一大堆,为什么我还要写"设计模式"的章节呢? 两个原因: 1.本人觉得这是一个有趣的设计模式使用实例,所以记下来: 2.看着设计模式很牛逼,却不知道怎么 ...

  8. 【node】使用nvm管理node版本

    写在前面 nvm(nodejs version manager)是nodejs的管理工具,如果你想快速更新node版本,并且不覆盖之前的版本:或者想要在不同的node版本之间进行切换: 使用nvm来安 ...

  9. 在centos6编译配置httpd2.4的N种方法

    前言 我们使用linux的过程中,一定会用到httpd这个服务,在centos7上,默认安装的httpd就是2.4版本,大家都知道,2.4版本相对之前的版本已经做了改进,用起来更加方便,但是我们的ce ...

  10. 安装debian 9.1后,中文环境下将home目录下文件夹改为对应的英文

    安装了debian 9.1后,中文环境下home目录下文件夹显示的是中文,相当不方便cd命令,改为对应的英文吧,需要用到的软件xdg-user-dirs-gtk #安装需要的软件 sudo apt i ...