分享更有价值
被信任是一种快乐

OGG怎么实现两台Oracle数据库的同步

文章页正文上

本篇内容介绍了“OGG怎么实现两台Oracle数据库的同步”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!首先我们看看实验环境环境源端是一个单实例
Oracle CENTOS6+ ORACLE 10.2.0.4
IP :192.168.56.101

目标端是一个单实例
OracleCENTOS 6+ ORACLE 10.2.0.4
IP :192.168.56.102

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

配置devdb到emrep的数据同步goldengate版本11.2.1.0

1.配置数据库信息在源端数据库中打开归档模式SQL>archive log listDatabase 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 loggingSQL>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 logSQL>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_Linu免费主机域名x_ora10g.tar配置环境变量源端和目标端:
修改goldengate用户的环境变量配置文件(ORACLE_SID按实际情况修改)
cat>>/home/goldengate/.bashrcORACLE_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的安装其实就是一个解压。非常简单。创建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源和目标端:

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

源端和目标端:

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“OGG怎么实现两台Oracle数据库的同步”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注云技术网站,小编将为大家输出更多高质量的实用文章!

相关推荐: MySQL中如何解决server has gone away问题

小编给大家分享一下MySQL中如何解决server has gone away问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! mysql出现ERROR : (2006, ‘MyS…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册