双向复制方案简介

在双向复制(Bidirectional)方案中,可以采用以下两种部署方式:

方式一:配置源和目标数据库可以同时保持Active 状态,同时进行应用系统的事务处理,

此时需由应用系统进行控制,避免对同一记录进行处理产生的冲突。

方式二:配置源为Active,目标为Standing-by,在源出现故障时,切换到目标数据库。

在源端和目标端都需要配置Extract 和Replicat 来实现双向复制。在双向复制方案中最重要的避免循环,即在由源数据库向目标端插入数据的时候,不应该再产生Trail(CDC 数据),否则将进入一个死循环。GoldenGate 采用排除同步时用户的方式来实现双向复制。

双向复制方案实现过程

在双向复制的过程中,每个数据库既是源数据库又是目标数据库,为便于理解,在下面的描述中,我们将左面的数据库称为“源数据库”,右面的数据库称为“目标数据库”。

2.1 同步表说明

本文以“TCUSTMER”表作为同步的数据库表。建表脚本如下:

CREATE TABLE tcustmer

(

cust_code VARCHAR2(4),

name VARCHAR2(30),

city VARCHAR2(20),

state CHAR(2),

PRIMARY KEY (cust_code)

USING INDEX

);

2.2 用户配置

2.2.1 同步用户

该用户用于在GoldenGate 中将源数据库中的数据同步到目标数据库,该用户必须能够访问源数据库用户和目标数据库用户下面的所有数据。

本文中以“gg_bi”作为同步用户。

2.2.2 源数据库用户

本文中以“gg_src”作为源数据库用户。

2.2.3 目标数据库用户

本文中以“gg_tgt”作为目标数据库用户。

2.3 源数据库端配置

2.3.1 增加Extract

GGSCI > ADD EXTRACT EXTBI, TRANLOG, BEGIN NOW, THREADS 1

EXTRACT added.

GGSCI > EDIT PARAMS EXTBI

EXTRACT EXTBI

USERID gg_bi, PASSWORD gg_bi ――该用户为同步用户

TRANLOGOPTIONS EXCLUDEUSER gg_bi ――将同步用户进行排除,避免循

RMTHOST <TARGET HOST>, MGRPORT 10002

RMTTRAIL ./dirdat/bi

TABLE gg_src.TCUSTMER; ――这里为实际要同步的用户及其数据库表

GGSCI > ADD RMTTRAIL ./dirdat/bi, EXTRACT EXTBI,MEGABYTES 5

GGSCI > START EXTRACT EXTBI

2.3.2 增加Replicat

下面是增加Check Point,如果已经配置检查点,则不用再次执行

GGSCI> EDIT PARAMS ./GLOBALS

增加下面一行

CHECKPOINTTABLE gg_src.ggschkpt

GGSCI> EXIT ――重新登录以激活global 参数

Shell> ggsci

GGSCI> DBLOGIN USERID gg_src, PASSWORD gg_src

GGSCI> ADD CHECKPOINTTABLE

GGSCI > ADD REPLICAT REPBI, EXTTRAIL ./dirdat/bi

REPLICAT added.

GGSCI > EDIT PARAM REPBI

REPLICAT REPBI

USERID gg_bi, PASSWORD gg_bi ――该用户为同步用户

HANDLECOLLISIONS

ASSUMETARGETDEFS

DISCARDFILE ./dirrpt/REPBI.DSC, PURGE

MAP gg_tgt.tcustmer, TARGET gg_src.tcustmer;

GGSCI > START REPLICAT REPBI

2.3.3 检查启动状态

查看Extract 和Replicat 状态,确保都正常运行

GGSCI > info all

Program Status Group Lag Time Since Chkpt

MANAGER RUNNING

EXTRACT RUNNING EXTBI 00:00:00 00:00:09

REPLICAT RUNNING REPBI 00:00:00 00:00:04

2.4 目标数据库配置

2.4.1 增加Extract

GGSCI > ADD EXTRACT EXTBI, TRANLOG, BEGIN NOW, THREADS 1

EXTRACT added.

GGSCI > EDIT PARAMS EXTBI

EXTRACT EXTBI

USERID gg_bi, PASSWORD gg_bi ――该用户为同步用户

TRANLOGOPTIONS EXCLUDEUSER gg_bi ――将同步用户进行排除,避免循

RMTHOST <SOURCE HOST>, MGRPORT 10001

RMTTRAIL ./dirdat/bi

TABLE gg_tgt.TCUSTMER;

GGSCI > ADD RMTTRAIL ./dirdat/bi, EXTRACT EXTBI,MEGABYTES 5

GGSCI > START EXTRACT EXTBI

2.4.2 增加Replicat

建立Check Point,同上,这里省略。

GGSCI > ADD REPLICAT REPBI, EXTTRAIL ./dirdat/bi

REPLICAT added.

GGSCI > EDIT PARAM REPBI

REPLICAT REPBI

USERID gg_bi, PASSWORD gg_bi ――该用户为同步用户

HANDLECOLLISIONS

ASSUMETARGETDEFS

DISCARDFILE ./dirrpt/REPBI.DSC, PURGE

MAP gg_src.tcustmer, TARGET gg_tgt.tcustmer;

GGSCI > START REPLICAT REPBI

2.4.3 检查启动状态

查看Extract 和Replicat 状态,确保都正常运行

GGSCI > info all

Program Status Group Lag Time Since Chkpt

MANAGER RUNNING

EXTRACT RUNNING EXTBI 00:00:00 00:00:03

REPLICAT RUNNING REPBI 00:00:00 00:00:01

测试

以gg_src 登录源数据库,执行insert 操作:

INSERT INTO tcustmer VALUES('WILL','BG SOFTWARE CO.','SEATTLE','WA');

以gg_tgt 登录目标数据库,执行insert 操作:

INSERT INTO tcustmer VALUES('JANE','ROCKY FLYER INC.','DENVER','CO');

在源数据库和目标数据库查看tcustomer 表,都应该包含新插入的两条记录。

在源数据库和目标数据库进行其它操作测试,测试后源数据库和目标数据库数据应保持一致。

GoldenGate 双向复制解决方案的更多相关文章

  1. 搭建一个Oracle到Oracle的Goldengate双向复制环境

    目标:搭建一个Oracle到Oracle的Goldengate双向复制环境(支持DDL+DML). 环境: OS:Red Hat Enterprise Linux Server release 5.5 ...

  2. Goldengate双向复制配置

    一.Goldengate双向复制配置 1.1.在进行如下配置之前,先在源数据库source system(原来的目标数据库)端 添加辅助的redolog配置: SQL>alter databas ...

  3. 【OGG】OGG基础知识整理

    [OGG]OGG基础知识整理 一.GoldenGate介绍 GoldenGate软件是一种基于日志的结构化数据复制软件.GoldenGate 能够实现大量交易数据的实时捕捉.变换和投递,实现源数据库与 ...

  4. OGG实现两台Oracle数据库的同步

    今天通过最简单的一个例子,给大家讲解下 goldengate 实现两台Oracle数据库的同步.内容如下:1.配置数据库信息.2.安装golden gate.3.配置golden gate.4.测试同 ...

  5. GoldenGate配置(二)之双向复制配置

     GoldenGate配置(二)之双向复制配置 环境: Item Source System Target System Platform Red Hat Enterprise Linux Serve ...

  6. oracle ogg 单实例双向复制搭建(oracle-oracle)--Oracle GoldenGate

    oracle ogg 单实例双向复制搭建(oracle-oracle)--Oracle GoldenGate --继昨天的测试,这一篇实施单实例双向复制(完全重新搭建) --环境不变 db1,db2( ...

  7. 异构GoldenGate 12c 双向复制配置

    1.配置window,添加checkpoint表(本文windows和linux互为source和target) GGSCI (WIN-GM5PVS1CILH) 1> view param ./ ...

  8. goldengate 12c 12.2 新特性(updated)

    GoldenGate 12.2已经提供下载,增加了不少新特性 1. 异构配置加强不在需要sourceDefs和AssumeTargetDefs文件,在队列文件中已经包含metadata信息,比如tab ...

  9. 使用 Oracle GoldenGate 在 Microsoft SQL Server 和 Oracle Database 之间复制事务

    使用 Oracle GoldenGate 在 Microsoft SQL Server 和 Oracle Database 之间复制事务 作者:Nikolay Manchev 分步构建一个跨这些平台的 ...

随机推荐

  1. bzoj1022: [SHOI2008]小约翰的游戏John(博弈SG-nim游戏)

    1022: [SHOI2008]小约翰的游戏John 题目:传送门 题目大意: 一道反nim游戏,即给出n堆石子,每次可以取完任意一堆或一堆中的若干个(至少取1),最后一个取的LOSE  题解: 一道 ...

  2. 1. Git-2.12.0-64-bit .exe下载

    转自:https://blog.csdn.net/u011164906/article/details/59129835 之前一直用SVN最近接触git,Git-2.12.0-64-bit .exe文 ...

  3. [JZOJ NOIP2018模拟10.20 A组]

    由于T3数据出锅,还不清楚自己的分数...估分150,前100已经拿到了,T3的50没拍过(写的就是暴力怎么拍),感觉很不稳 考试的时候就是特别的困,大概是因为早上在房间里腐败...腐败完了才睡觉 T ...

  4. 递归版快速排序-JS代码

    "use strict" var arr1=[11,21,3,4,0]; function qSort(arr){ var mid,left,right,len,i,j,empty ...

  5. 51nod 1402 最大值 3级算法题 排序后修改限制点 时间复杂度O(m^2)

    代码: 题意,第一个数为0,相邻的数相差0或者1,有一些点有限制,不大于给定值,求这组数中可能的最大的那个数. 这题我们看一个例子:第5个数的限制为2 1 2 3 4 5 6 7 8 9 0 1 2 ...

  6. Net Core链接数据库

    原文 在Windows下,相信大家分分钟都可以搞定.而初次接触.net core + mysql可能需要注意些细节.首先打开vs2017新建一个asp.net core项目(选Web应用程序), 然后 ...

  7. fastdfs+nginx的安装部署

    原理图: fastdfs适用场景: fastdfs特别适合海量 中小文件(建议范围:4KB< file_size <500MB)为载体的在线服务. 安装系统介绍: CentOS6.6 安装 ...

  8. SpringCloud学习笔记(15)----Spring Cloud Netflix之Hystrix Dashboard的使用

    1. 引入依赖 在前面几节中的消费者中添加pom依赖. <dependency> <groupId>org.springframework.cloud</groupId& ...

  9. 设置fixed,横向滚动条失效

    window.onscroll = function(){ var sl = -Math.max(document.body.scrollLeft,document.documentElement.s ...

  10. 微信小程序手势滑动卡片案例

    最近工作中有项目要使用微信小程序技术进行开发,其中一项功能困扰了我很久,卡片滑动动效以及手势识别.经过一番研究和参考,现在把成果展示.记录自己踩到的坑,如果大家有需要,也可以帮助到大家. 效果图: 首 ...