Oracle GoldenGate实现Windows与Windows之间的单向同步sql
本次实验都是在win环境进行,目的经过GoldenGate实现Windows与Windows之间的单向同步进行对源库复制备份。数据库
实验环境说明服务器
操做系统:Windows 2008 R2 ,oracle
数据库:oracle 11.2.0.1.0 ,app
GoldenGate:11.2.1.0.3 for Microsoft Windows x64ide
下载地址:http://down.51cto.com/data/2448081测试
1、安装前环境检查(source端与target端安装相同):spa
一、 检查数据库配置状况操作系统
检查归档模式、附加日志、强制日志参数是否开启。.net
SQL> select log_mode,supplemental_log_data_min,force_logging from v$database;
默认状况下归档模式、附加日志、强制日志参数是关闭的。
启动归档模式、附加日志、强制日志。其中开启归档模式须要重启数据库,开启附加日志、强制日志不须要重启数据库。
SQL> shutdown immediate;
SQL> startup mount;
SQL> alter database archivelog;
SQL> alter database force logging;
SQL> alter database add supplemental log data;
SQL> alter database open;
2、安装GoldenGate
1 首先将Oracle GoldenGate 11.2.1.0.3 for Microsoft Windows x64 (64-bit)拷贝到并解压缩到D:\app\Administrator\目录下(该路径能够根据须要自行选择),解压完成后将目录名改成ogg。
2 进入D:\app\Administrator\ogg\目录,运行ggsci,进入ogg管理控制台。
3 在ogg控制台输入命令:create subdirs,让ogg建立其须要用到的目录
4 将D:\app\Administrator\ogg目录下的category.dll和ggsmsg.dll文件拷贝到SYSTEM32目录中。
5 手工在ogg目录下建立discard文件夹:md discard
6 在Oracle中建立GoldenGate专属用户ogg,要先建立独立的表空间给ogg用户,不然后面安装会报错;
D:\app\Administrator\ogg>sqlplus / as sysdba
SQL> create tablespace ogg_tbs datafile 'd:\app\administrator\oradata\hwprod\ogg_tbs01.dbf' size 1024M;
SQL> alter tablespace ogg_tbs add datafile 'd:\app\administrator\oradata\hwprod\ogg_tbs02.dbf' size 1024m;
SQL> alter tablespace ogg_tbs add datafile 'd:\app\administrator\oradata\hwprod\ogg_tbs03.dbf' size 1024m;
SQL>create user ogg identified by oracle default tablespace ogg_tbs quota unlimited on ogg_tbs;
SQL>grant dba to ogg; (涉及到DDL复制,需授予给dba权限)
SQL> grant execute on utl_file to ogg;
7为新建立的ogg用户执行配置脚本。在ogg的安装目录下使用sys登录sqlplus,而后执行markker_setup.sql,ddl_setup.sql,role_setup.sql,ddl_enable.sql。
(1) marker_setup.sql,做用是安装DDL支持所须要的GoldenGate marker系统。
SQL>@ marker_setup
(2) ddl_setup.sql
SQL>@ddl_setup
(3) role_setup.sql,做用是删除和建立DDL同步须要的角色,它受权DDL对象上的DML操做。
SQL>@role_setup
SQL> grant GGS_GGSUSER_ROLE to ogg;
(4) ddl_enable.sql,做用是启用ddl触发器。
SQL> @ddl_enable
8 进入ogg控制台,测试用户是否建立成功。
GGSCI (HWORATEST) 1> dblogin userid ogg
测试成功,安装完成!
3、配置GoldenGate
source端
一、 配置Manager管理进程参数:
GGSCI (HWORATEST) 1> edit params mgr
点击 “是”
而后键入如下内容并保存
port 7809
二、 配置checkpoint表
GGSCI (HWORATEST) 3> edit params ./GLOBAL
点击“是” 并输入如下内容保存
GGSCHEMA ogg
CHECKPOINTTABLE ogg.checkpoint
添加checkpoint表
GGSCI (HWORATEST) 7> add checkpointtable ogg.checkpoint
添加操做前,请注意先登陆
三、 配置服务器的抽取进程
GGSCI (HWORATEST) 8> add extract ext_w1,tranlog, begin now
GGSCI (HWORATEST) 9> add exttrail d:\app\Administrator\ogg\dirdat\wt, extract ext_w1
GGSCI (HWORATEST) 10> edit params ext_w1
点击 “是”并输入如下内容保存
ddl include all
extract ext_w1
userid ogg, password oracle
exttrail D:\app\Administrator\ogg\dirdat\wt
table prun.*;
注意,上述是包含DDL复制,主要是对prun的全部对象操做
四、 配置服务器的投递进程
GGSCI (HWORATEST) 11> add extract pum_w1, exttrailsource D:\app\Administrator\ogg\dirdat\wt, begin now
GGSCI (HWORATEST) 12> add rmttrail D:\app\Administrator\ogg\dirdat\rt, extract pum_w1
GGSCI (HWORATEST) 13> edit params pum_w1
点击 “是” ,并输入如下内容保存
extract pum_w1
userid ogg, password oracle
rmthost 192.168.10.19, mgrport 7809
rmttrail D:\app\Administrator\ogg\dirdat\rt
table prun.*;
注意,上述IP为target端IP地址
至此,soure端配置基本完毕,能够info all查看:
如下进行target端相关配置:
一、 配置Manager管理进程参数:
GGSCI (HWOGG01) 2> edit params mgr
点击“是”输入如下内容并保存
port 7809
二、 配置checkpoint表
GGSCI (HWOGG01) 3> edit params ./GLOBAL
点击“是”,输入如下内容并保存
GGSCHEMA ogg
CHECKPOINTTABLE ogg.checkpoint
添加checkpoint表
GGSCI (HWOGG01) 4> add checkpointtable ogg.checkpoint
三、 配置目标服务器的复制进程
GGSCI (HWOGG01) 5>add replicat rep_w2, exttrail d:\app\Administrator\ogg\dirdat\rt, checkpointtable ogg.checkpoint
GGSCI (HWOGG01) 6> edit params rep_w2
点击“是”,输入如下内容并保存
replicat rep_w2
ddl include all
ddlerror default ignore retryop maxretries 3 retrydelay 5
userid ogg, password oracle
assumetargetdefs
discardfile d:\app\Administrator\ogg\dirdat\rep_w2_discard,append
map prun.*, target prun.*
RESOLVECONFLICT (UPDATEROWEXISTS, (DEFAULT, OVERWRITE))
RESOLVECONFLICT (INSERTROWEXISTS, (DEFAULT, OVERWRITE))
RESOLVECONFLICT (DELETEROWEXISTS, (DEFAULT, OVERWRITE))
RESOLVECONFLICT (UPDATEROWMISSING, (DEFAULT, IGNORE))
RESOLVECONFLICT (DELETEROWMISSING, (DEFAULT, IGNORE));
配置完毕,查看相关信息
4、验证测试
最后启动两端mgr进程,并测试(相关命令使用能够键入help查找)
首先启动source端
Start mgr
Start ext_w1
Start pum_w1
启动target端:
Start mgr
Start rep_w2
检查target端是否有如下表存在,若是没有,则在source端建立上述表,而后检查是否会复制过来
target端检查:
source端 进行建表操做
SQL>create table prun.TESTOGG as select * from prun.cts_role;
再检查target端
测试成功!