Oracle Golden Gate软件是一种基于日志的结构化数据复制备份软件,它经过解析源数据库在线日志或归档日志得到数据的增量变化,再将这些变化应用到目标数据库,从而实现源数据库与目标数据库同步。Oracle Golden Gate能够在异构的IT基础结构(包括几乎全部经常使用操做系统平台和数据库平台)之间实现大量数据亚秒一级的实时复制,从而在能够在应急系统、在线报表、实时数据仓库供应、交易跟踪、数据同步、集中/分发、容灾、数据库升级和移植、双业务中心等多个场景下应用。同时,Oracle Golden Gate能够实现一对1、广播(一对多)、聚合(多对一)、双向、点对点、级联等多种灵活的拓扑结构html
Oracle GoldenGate(下文简称ogg)软件能够经过ORACLE官方网站进行下载,根据ORACLE的版本及操做系统来下载对应版本的ogg,官方下载地址:linux
http://www.oracle.com/technetwork/middleware/goldengate/downloads/index.htmlsql
ogg安装很是简单,但需在源数据库和目标数据库服务器上均安装ogg软件便可,具体请参考如下步骤:数据库
一、 将压缩包解压到系统目录/oracle/ogg (该路径能够根据须要自行选择)服务器
二、 进入/oracle/ogg目录,运行./ggsci,进入ogg管理控制台session
三、 在ogg控制台输入命令: create subdirs ,让ogg建立其须要用到的目录oracle
四、 手工在ogg目录下建立discard文件夹,mkdir discardapp
五、 配置操做系统环境变量(请确保环境变量配置了ORACLE_HOME和ORACLE_SID)ide
export LD_LIBRARY_PATH=/oradata/ogg:$ORACLE_HOME/lib:$LD_LIBRARY_PATH测试
六、 在ORACLE中建立ogg专属用户
[oracle@local ~]$ sqlplus /nolog
SQL> conn / as sysdba
SQL> create user ogg identified by ogg; (注:帐号密码根据实际状况设置)
SQL> grant connect,resource to ogg;
SQL> grant unlimited tablespace to ogg;
SQL> grant execute on utl_file to ogg;
七、 为新建立的ogg用户执行配置脚本
在ogg的安装目录下登录sqlplus,使用sys登录sqlplus,而后执行以下配置
[oracle@local ~]$ sqlplus /nolog
SQL> conn / as sysdba
SQL> @marker_setup.sql
SQL> @ddl_setup.sql;
SQL> @role_setup.sql;
SQL> grant GGS_GGSUSER_ROLE to ogg;
SQL> @ddl_enable.sql;
进入ogg控制台,测试用户是否建立成功
GGSCI (local) 1> dblogin userid ogg
Password: ogg
Successfully logged into database.
经过上述步骤,ogg就安装成功了。
为了能让ogg成功的将源数据库及目标数据库进行同步,下面还须要对ogg及oracle进行一系列配置(ogg支持多种复制方式,好比单项复制、双向复制等等,因实际须要,本文仅介绍单项复制相关配置)。
首先说说ogg的一些概念:
一、 Manager:ogg全部服务必须依赖Manager,Manger如同ogg的总调度。
二、 Extract :ogg用来获取源数据库数据更新的,将变动的数据发送到目标数据库
三、 Replicat :ogg用来接收源数据库的更新,一旦源数据库Extract将数据发送过来后,Replicat会自动将更新脚本同步到目标数据库。
一、开启ORACLE归档模式,设置日志模式
[oracle@local ~]$ sqlplus /nolog
SQL> conn / as sysdba
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;
二、 回收站功能会影响同步,须要关闭回收站
SQL>alter session set recyclebin=off;
SQL>alter system set recyclebin=off;
三、配置环境变量NLS_LANG(不配置中文同步会乱码)
首先在oracle中查询select userenv( 'language') from dual;
而后将查询的结果配置到linux环境变量中
如export NLS_LANG=” SIMPLIFIED CHINESE_CHINA.ZHS16GBK”
四、登录ogg控制台,设置须要进行同步的oracle表
GGSCI (local) 1> dblogin userid ogg
GGSCI (local) 1> add trandata dbuser.*
五、配置ogg manager&启动manager(配置界面操做相似vi)
GGSCI (local) 1> edit param mgr
PORT 7809
GGSCI (local) 1> info all(查看当前mgr状态)
GGSCI (local) 1> start manager(启动manager,启动完后能够用info all再次查看状态)
六、 添加一个ogg extract进程,用于抽取源服务器数据
GGSCI (local) 1> add extract ext4,tranlog,begin now (增长一个抽取进程ext4,ext4名字能够根据须要修改)
GGSCI (local) 1> add exttrail /oracle/ogg/dirdat/wf,extract ext4 (将ext4抽取的源数据变动数据写到该文件夹)
GGSCI (local) 1> edit params ext4 (修改ext4的配置参数)
extract ext4
userid ogg,password ogg
rmthost xxxx.xxx.xxx.xxx,mgrport 7809 --目标服务器ip
rmttrail /oracle/ogg/dirdat/wf --目标服务器文件夹
ddl include mapped objname dbuser.*;
table dbuser.*;
配置完成后能够经过info all查看到新添加的extract的状态
七、启动ogg extract命令
GGSCI (local) 1> start extract ext4 (等目标服务器ogg配置成功后再启动ext)
一、登录ogg控制台
GGSCI (local) 1> dblogin userid ogg
二、配置ogg manager&启动manager(配置界面操做相似vi)
GGSCI (local) 1> edit param mgr
PORT 7809
DYNAMICPORTLIST 7840-7850 --远程队列端口范围
GGSCI (local) 1> info all(查看当前mgr状态)
三、 添加一个ogg replicat进程,用于更新目标服务器数据
GGSCI (local) 1> edit params ./GLOBAL
GSSCHEMA ogg
CHECKPOINTTABLE ogg.checkpoint
GGSCI (local) 2> dblogin userid ogg
Password: ogg
Successfully logged into database.
GGSCI (local) 3> add checkpointtable ogg.checkpoint
Successfully created checkpoint table ogg.CHECKPOINT.
GGSCI (local) 4> ADD replicat rep2 EXTTRAIL /hom/wangfan/ggs/dirdat/wf, checkpointtable ogg.checkpoint
GGSCI (local) 5> edit param rep2
--Replicat group --
replicat rep2
--source and target definitions
ASSUMETARGETDEFS
--target database login --
userid ogg, password ogg
--file for dicarded transaction --
discardfile /oracle/ogg/discard/rep2_discard.txt, append, megabytes 10
--ddl support DDL
DDL INCLUDE MAPPED
DDLERROR DEFAULT IGNORE RETRYOP
--Specify table mapping ---
map dbuser.*, target dbuser.*;
配置完成后能够经过info all查看到新添加的extract的状态
四、启动ogg manager & replicat命令
GGSCI (local) 1> start manager
GGSCI (local) 1> start replicat rep2
最后参考源服务器配置,启动ext4
一、 启动manager:start manager
二、 启动extract:start extract extn
三、 启动replicat:start replicat repn
四、 中止manager:stop manager
五、 中止 extract:stop extract extn
六、 中止replicat:stop replicat repn
七、 删除extract:delete extract extn
八、 删除replicat:delete extract repn
九、 查看ogg状态:info all
十、 修改manager参数:edit params mgr
十一、 修改extract参数:edit params extn
十二、 修改replicat参数:edit params repn
1三、 修改全局参数:edit params ./GLOBAL
$OGG_HOME/ggserr.log
操做系统设置:
一、用oracle用户创建/oracle/ogg/autostart/info.txt,文件内容以下:
sh dat
start mgr
二、chmod x info.txt
三、用oracle用户创建/oracle/ogg/autostart/startmgr.sh,文件内以下:
/oracle/ogg/ggsci paramfile /oracle/ogg/autostart/info.txt >> /oracle/ogg/autostart/log.txt
四、chmod x startmgr.sh
五、用root用户编辑 /etc/rc.local ,添加以下信息:
su - oracle -c "/oracle/ogg/autostart/startmgr.sh"
OGG设置:
在ogg中主进程是manager进程,使用startmgr启动。能够在mgr进程中添加一些参数用来在启动mgr进程的同时启动extract和replicat进程。
一、如下是extract端的mgr参数配置
GGSCI (gg01) 130> edit params mgr
PORT 7809
DYNAMICPORTLIST 7800-7909
--启动mgr进程启动启动extract进程
AUTOSTART EXTRACT *
--extract异常终止时会自动启动,每5分钟尝试从新启动全部的extract进程,一共尝试3次,5分钟清零
AUTORESTART EXTRACT *,RETRIES 3, WAITMINUTES 5, RESETMINUTES 10
二、配置目标端replicat进程自启动,在mgr参数中添加以下
GGSCI (gg02) 140> edit params mgr
PORT 7809
--动态端口,当指定端口不可用时,会从如下列表中选择一个可用端口
DYNAMICPORTLIST 7800-7909
--自动启动replicat进程
AUTOSTART REPLICAT *
--当replicat进程异常终止时会自动启动,每5分钟尝试从新启动全部的replicat进程,一共尝试5次
AUTORESTART REPLICAT *, WAITMINUTES 2, RETRIES 5
--mgr每隔1小时检查extract延时状况,超5分钟做为信息记录log中,超过7分钟做为警告记录log中
LAGREPORTHOURS 1
LAGINFOMINUTES 5
LAGCRITICALMINUTES 7
--删除10天前的trail文件
PURGEOLDEXTRACTS /oracle/ogg/dirdat/*, USECHECKPOINTS, MINKEEPDAYS 10