gg oracle tjs 同步_OGG实现两台Oracle数据库的同步

今天通过最简单的一个例子,给大家讲解下 goldengate 实现两台Oracle数据库的同步。

内容如下:

1.配置数据库信息。

2.安装golden gate.

3.配置golden gate.

4.测试同步情况

首先我们看看实验环境

环境

源端是一个单实例

Oracle Enterprise 5 + ORACLE 10.2.0.4

IP :10.4.128.100

目标端是一个单实例

Oracle Enterprise 5 + ORACLE 10.2.0.4

IP :10.4.128.101

两台主机均已创建数据库,sid分别为devdb 和 emrep

配置devdb 到 emrep的数据同步

goldengate版本11.2.1.0

1.配置数据库信息

在源端数据库中打开归档模式

SQL> archive log list

Database log mode              Archive Mode

Automatic archival             Enabled

Archive destination            /u01/archive1

Oldest online log sequence     180

Next log sequence to archive   181

Current log sequence           181

若处于非归档模式,则改为归档模式:

SQL> shutdown immediate

Database closed.

Database dismounted.

ORACLE instance shut down.

SQL> startup mount;

ORACLE instance started.

SQL> alter database archivelog;

Database altered.

SQL> alter database open;

Database altered.

在源端数据库中打开force logging

SQL> select force_logging from v$database;

FOR

---

NO

SQL> alter database force logging;

Database altered.

SQL> select force_logging from v$database;

FOR

---

YES

在源端数据库中打开supplemental log

SQL> select supplemental_log_data_min from v$database;

SUPPLEME

--------

NO

SQL> alter database add supplemental log data;

Database altered.

切换日志,使更改生效

SQL> alter system switch logfile;

System altered.

SQL> select supplemental_log_data_min from v$database;

SUPPLEME

--------

YES

在源端数据库中关闭回收站

官方的说明是,由于一个已知的问题,回收站会对DDL触发器产生影响,因此需要关闭。由此可见,我们只需要在源库中关闭回收站即可。

SQL> show parameter recyclebin

NAME TYPE VALUE

------------------------------------ ----------- ------------------------------

recyclebin string on

SQL> alter system set recyclebin=off;

System altered.

SQL> show parameter recyclebin

NAME TYPE                                VALUE

------------------------------------ -------------------------------

recyclebin string                          OFF

创建goldengate数据库用户(源和目标)

注意:源和目标端都需要

[oracle@rac1 ~]$ sqlplus / as sysdba

SQL*Plus: Release 10.2.0.4.0 - Production on Fri Jan 9 11:56:28 2015

Copyright (c) 1982, 2007, Oracle. All Rights Reserved.

Connected to:

Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 - 32bit Production

With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL> create tablespace goldengate;

Tablespace created.

SQL> create user goldengate identified by goldengate default tablespace goldengate;

User created.

SQL> grant connect,resource to goldengate;

Grant succeeded.

SQL> grant execute on utl_file to goldengate;

Grant succeeded.

SQL>

抽取进程使用的数据库用户需要额外的权限,我们将这些权限也授予数据库用户goldengate(在源端数据库中执行)

SQL> exec dbms_streams_auth.grant_admin_privilege('GOLDENGATE');

PL/SQL procedure successfully completed.

SQL> grant insert on system.logmnr_restart_ckpt$ to goldengate;

Grant succeeded.

SQL> grant update on sys.streams$_capture_process to goldengate;

Grant succeeded.

SQL> grant become user to goldengate;

Grant succeeded.

SQL>

为了确保GoldenGate正常运行,特别是在目标端,赋予goldengate用户DBA权限:

SQL> grant dba to goldengate;

2.GoldenGate安装环境

解压goldengate安装文件到安装目录

安装GoldenGate软件很简单,解压即可

以goldengate用户登录

[goldengate@rac1 goldengateMedia]$ mkdir /opt/gg/goldengate、

[goldengate@rac1 goldengateMedia]$ cp ggs_Linux_ora10g_.tar /opt/gg/goldengate

[goldengate@rac1 goldengateMedia]$ cd /opt/gg/goldengate

[goldengate@rac1 goldengate]$ tar -xvf ggs_Linux_ora10g.tar

配置环境变量

源端和目标端:

修改goldengate用户的环境变量配置文件(ORACLE_SID按实际情况修改)

cat>>/home/goldengate/.bashrc<

ORACLE_HOME=/opt/app/oracle/product/10.2.0/db_1

export ORACLE_HOME

ORACLE_SID=devdb

export ORACLE_SID

GG_HOME=/opt/gg/goldengate

export GG_HOME

PATH=\$ORACLE_HOME/bin:$GG_HOME:\$PATH

export PATH

LD_LIBRARY_PATH=\$ORACLE_HOME/lib:\$GG_HOME:\$LD_LIBRARY_PATH

export LD_LIBRARY_PATH

EOF

应用刚刚修改的环境变量,然后进入GoldenGate安装目录,执行ldd ggsci,确定需要的库文件都能够找到。如果出现共享库文件无法找到,例如libnnz10.so => not found,检查LD_LIBRARY_PATH环境变量的设置

[goldengate@ggdb goldengate]$ source ~/.bashrc

[goldengate@ggdb goldengate]$ cd $GG_HOME

[goldengate@ggdb goldengate]$ ldd ggsci

我们可以认为ogg的安装其实就是一个解压。非常简单。

3.配置goldengate

创建goldengate工作目录

源端和目标端:

[goldengate@rac1 goldengate]$ cd $GG_HOME

[goldengate@rac1 goldengate]$ ./ggsci

GGSCI (rac1) 1> create subdirs

Creating subdirectories under current directory /opt/gg/goldengate

Parameter files /opt/gg/goldengate/dirprm: created

Report files /opt/gg/goldengate/dirrpt: created

Checkpoint files /opt/gg/goldengate/dirchk: created

……

GGSCI (gg1) 2> exit

创建trail文件存放目录

源和目标端:

[goldengate@rac1 ~]$ mkdir /opt/gg/trails

[goldengate@rac1 ~]$ ls -l /opt/gg | grep trails

配置MANAGER

源端和目标端:

DYNAMICPORTLIST中配置了GoldenGate(extract和replicat)进程使用的端口范围

PORT参数指定MANAGER使用的端口

AUTORESTART参数使抽取/复制进程失败后自动重启

配置MANAGER的参数,PURGEOLDEXTRACTS参数指定:当根据checkpoint发现已经完成抽取和复制的trail文件将被自动删除,但保留最近10个。

PURGEDDLHISTORY和PURGEMARKERHISTORY分别删除DDL历史表和marker表中的过期数据,以控制它们不会变得过于庞大。

GGSCI (gg1) 1> edit params mgr

PORT 5898

PURGEOLDEXTRACTS /opt/gg/trails/w1*, USECHECKPOINTS, MINKEEPFILES 10

AUTORESTART ER *, RETRIES 3, WAITMINUTES 5

PURGEDDLHISTORY MINKEEPDAYS 3, MAXKEEPDAYS 5, FREQUENCYMINUTES 30

PURGEMARKERHISTORY MINKEEPDAYS 3, MAXKEEPDAYS 5, FREQUENCYMINUTES 30

全局参数设置

源端:

GGSCI (rac1) 2> edit params ./globals

GGSCHEMA goldengate

目标端:

创建一个checkpoint表

replicat通过这个表来维护trail文件中的read position。这不是个必须的操作,如果没有这个表,则通过一个磁盘文件来维护

GGSCI (ggdb) 2> dblogin userid goldengate,password goldengate

Successfully logged into database.

GGSCI (ggdb) 3> add checkpointtable goldengate.chkpoint

Successfully created checkpoint table GOLDENGATE.CHKPOINT.

GGSCI (ggdb) 4> edit params ./globals

GGSCHEMA goldengate

CHECKPOINTTABLE goldengate.chkpoint

补充日志: Supplemental Log是一种补充类型的日志,主要用于逻辑Standby数据库的同步、LogMiner、Streams和Flashback等技术。对于逻辑Standby数据库来说,不能通过ROWID来标识某一行,Oracle推荐使用主键、约束和索引唯一标识行数据,但如果某部分表由于某种原因没有主键、唯一约束和唯一索引,不能有效的标识行数据,那么必须通过Supplemental Log记录多个字段甚至所有字段值来唯一标识表行。

oracle scope=both和scope=spfile区别:

Oracle spfile就是动态参数文件,里面设置了Oracle 的各种参数。所谓的动态,

就是说你可以在不关闭数据库的情况下,更改数据库参数,记录在spfile里面。更改参数

的时候,有4种scope选项,scope就是范围。

scope=spfile 仅仅更改spfile里面的记载,不更改内存,也就是不立即生效,而是等

下次数据库启动生效。

有一些参数只允许用这种方法更改,scope=memory 仅仅更改内存,不改spfile。也就是下次

启动就失效了

scope=both 内存和spfile都更改,不指定scope参数,等同于scope=both。

日志记录模式(LOGGING 、FORCE LOGGING 、NOLOGGING):https://blog.csdn.net/leshami/article/details/6130866

https://blog.csdn.net/huoshuyinhua/article/details/79467606

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值