KunlunBase 快速入门 4.0(从Oracle实时同步数据到KunlunBase)

2022-04-07 00:00:00 数据 数据库 配置 进程 复制

一、环境及软件需求


Oracle GoldenGate从11.2.1.0.2开始支持在Oracle数据库和 KunlunBase  之间做数据复制。


本文档提供数据复制过程的基本配置方案,涉及不同操作系统及数据库版本具体配置,请参考官方文档。

 

软件需求:

  • Oracle GoldenGate for Oracle

  • Oracle GoldenGate for Postgresql

  • 软件下载页面:https://www.oracle.com/middleware/technologies/goldengate.html


数据同步架构图



二、安装


2.1 安装&配置Oracle GoldenGate for Oracle

 

Oracle数据库服务器端环境变量。

ORACLE_HOME=/opt/oracle/product/19c/dbhome_1ORACLE_SID=kunluntestLD_LIBRARY_PATH=$ORACLE_HOME/lib


Oracle数据库运行在归档模式并且开启附加日志。

alter system set log_archive_dest='LOCATION=USE_DB_RECOVERY_FILE_DEST'scope=both sid='*';shutdown immediatestartup mountalter database archivelog;alter database open;alterdatabaseaddsupplementallogdata; 


安装Oracle GoldenGate for Oracle并设置GoldenGate软件目录到环境变量。

exportPATH=$PATH:/var/kunlun/ggsexportLD_LIBRARY_PATH=$ORACLE_HOME/lib:/var/kunlun/ggs/lib/LD_LIBRARY_PATH


为Goldengate 配置基本目录。

GGSCI (SOURCE.KUNLUN.COM)1> create subdirsCreatingsubdirectories under current directory /var/kunlun/ggsParameterfiles        /var/kunlun/ggs/dirprm:alreadyexistsReportfiles          /var/kunlun/ggs/dirrpt:createdCheckpointfiles        /var/kunlun/ggs/dirchk:createdprocessstatusfiles      /var/kunlun/ggs/dirpcs:createdSQLscriptfiles        /var/kunlun/ggs/dirsql:createdDatabasedefinitionsfiles   /var/kunlun/ggs/dirdef:createdExtractdatafiles      /var/kunlun/ggs/dirdat:createdTemporaryfiles        /var/kunlun/ggs/dirtmp:createdStdoutfiles          /var/kunlun/ggs/dirout:created


创建OGG manager 参数文件。

GGSCI(SOURCE.KUNLUN.COM)2>editparammgraddPORT7809 to  theparameterfile:


启动 OGG manager。

GGSCI(SOURCE.KUNLUN.COM)3>startmgrGGSCI(SOURCE.KUNLUN.COM)4>infoallProgram   Status   Group    LagatChkptTimeSinceChkptaddPORT7809 to  theparameterfile:MANAGER   RUNNING


2.2 安装&配置Oracle GoldenGate for KunlunBase

 

在PostgreSQL服务器端解压GoldenGate软件包并发lib路径配置到环境变量中。

mkdir ggscd ggsunzip V34006-01.ziptar xvf *.tar[kunlun@centos7b ggs]$ export LD_LIBRARY_PATH=/var/kunlun/ggs/lib

 

GoldenGate通过ODBC连接  KunlunBase   ,因此,需要配置ODBC 数据源。

[ODBC Data Sources]Kunlundb1=DataDirect 11.5 KUNLUNDB Wire Protocol[ODBC]IANAAppCodePage=106InstallDir=/var/kunlun/ggs[kunlundb1]Driver=/var/kunlun/ggs/lib/GGpsql25.soDescription=DataDirect 11.5 KUNLUNDB Wire ProtocolDatabase=kunlundbHostName=192.168.0.130PortNumber=5401LogonID=abcPassword=abc

将配置文件export到环境变量。

[kunlun@centos7b  ggs]$ export ODBCINI=/var/kunlun/ggs/odbc.ini

配置目标端Goldengate。

[kunlun@TARGET ggs]$ ./ggsciGGSCI (TARGET.KUNLUN.COM) 1> create subdirs
Creating subdirectories under current directory /var/kunlun/ggs
Parameter files /var/kunlun/ggs/dirprm: already existsReport files /var/kunlun/ggs/dirrpt: createdCheckpoint files /var/kunlun/ggs/dirchk: createdProcess status files /var/kunlun/ggs/dirpcs: createdSQL script files /var/kunlun/ggs/dirsql: createdDatabase definitions files /var/kunlun/ggs/dirdef: createdExtract data files /var/kunlun/ggs/dirdat: createdTemporary files /var/kunlun/ggs/dirtmp: createdStdout files /var/kunlun/ggs/dirout: created
create the Manager parameter file and start the manager:GGSCI (TARGET.KUNLUN.COM) 2> edit param mgr PORT 7809 GGSCI(TARGET.KUNLUN.COM) 3> start mgrManager started.
GGSCI (TARGET.KUNLUN.COM) 4> info allProgram Status Group Lag at Chkpt Time Since ChkptMANAGER RUNNING

目标端新增checkpoint表。

-- ogg中执行
dblogin sourcedb KUNLUNDB userid abc password abcadd checkpointtable ogg.checkpointtab



三、准备测试表

 

分别在Oracle数据库和 KunlunBase  集群中建立结构相同的一张表。

 

Oracle DB

SQL> connect kunlun/kunlunConnected.SQL> create table kunluntest (col1 number, col2varchar2(20));Table created.SQL> alter table kunluntest add primary key (col1);Table altered.

 

KunlunBase

KunlunDB>CREATE TABLE "public"."kunluntest"( "col1"integer NOT NULL, "col2"varchar(20), CONSTRAINT"PK_Col111" PRIMARY KEY ("col1"))


 

3.1 验证到OGG到Oracle数据库的连接

 

在Oracle端执行ggsci。

GGSCI (SOURCE.KUNLUN.COM) 8> dblogin userid kunlun,password kunlunSuccessfully logged into database.GGSCI (SOURCE.KUNLUN.COM) 9> list tables *KUNLUN.KUNLUNTESTFound 1 tables matching list criteria.
GGSCI (SOURCE.KUNLUN.COM) 10> capture tabledefKUNLUN.KUNLUNTESTTable definitions for KUNLUN.KUNLUNTEST:COL1 NUMBER NOT NULL PKCOL2 VARCHAR (20)

3.2 验证到OGG到 KunlunBase  数据库的连接

 

KunlunBase  端执行ggsci。

GGSCI (TARGET.KUNLUN.COM) 4> dblogin sourcedb kunlundbuserid abcPassword:2013-04-06 16:51:18 INFO OGG-03036 Database character setidentified as UTF-8.Locale: en_US.2013-04-06 16:51:18 INFO OGG-03037 Session character setidentified as UTF-8.Successfully logged into database.GGSCI (TARGET.KUNLUN.COM) 5> list tables *public.kunluntest
Found 1 tables matching list criteria.GGSCI (TARGET.KUNLUN.COM) 3> capture tabledef"public"."kunluntest"Table definitions for public.kunluntest:col1 NUMBER(10) NOT NULL PKcol2                                                              VARCHAR (20)


 

四、配置抽取进程


配置一个抽取进程,抽取表Oracle数据库中的表kunluntest的数据增量到trail文件中。


首先配置MGR 参数:

GGSCI (SOURCE.ORACLE.COM) 4> edit param epor
with these parameters:
EXTRACT eporUSERID kunlun, PASSWORD kunlunRMTHOST 192.168.0.130, MGRPORT 7809RMTTRAIL ./dirdat/epTABLE kunlun.kunluntest;

 

启动抽取进程。

GGSCI (SOURCE.ORACLE.COM) 5> add extract epor, tranlog,begin nowEXTRACT added.GGSCI (SOURCE.ORACLE.COM) 6> add exttrail ./dirdat/ep,extract epos, megabytes 5EXTTRAIL added.
GGSCI (SOURCE.ORACLE.COM) 7> start eporSending START request to MANAGER ...EXTRACT EPOR starting
GGSCI (SOURCE.ORACLE.COM) 8> info all
Program Status Group Lag at Chkpt Time Since ChkptMANAGER RUNNINGEXTRACT  RUNNING   EPOR    00:00:00  00:00:05


 

五、创建定义文件


在OGG中,异构数据库之间的数据同步需要为源端创建定义文件。

GGSCI (SOURCE.KUNLUN.COM) 10> edit param defgenDEFSFILE ./dirdef/KUNLUNTEST.defUSERID kunlun, password kunlunTABLE KUNLUN.KUNLUNTEST;[kunlun@SOURCE ggs]$ ./defgen paramfile ./dirprm/defgen.prm
*********************************************************************** Oracle GoldenGateTable Definition Generator for Oracle Version 11.2.1.0.314400833 OGGCORE_11.2.1.0.3_PLATFORMS_120823.1258Copyright (C) 1995, 2012, Oracle and/or its affiliates. Allrights reserved.
Starting at2022-03-15 18:32:10***********************************************************************
Operating System Version:LinuxNode: SOURCE.KUNLUN.COMMachine: x86_64 softlimit hard limitAddress Space Size : unlimited unlimitedHeap Size : unlimited unlimitedFile Size : unlimited unlimitedCPU Time : unlimited unlimited
Process id: 1546
************************************************************************* Running withthe following parameters *************************************************************************DEFSFILE ./dirdef/KUNLUNTEST.defUSERID postgres, password ********TABLE KUNLUN.KUNLUNTEST;Retrieving definition for KUNLUN.KUNLUNTEST
Definitions generated for 1 table in ./dirdef/KUNLUNTEST.def
Content of the Defgen File:[oracle@SOURCE ggs]$ more ./dirdef/KUNLUNTEST.def*+- Defgen version 2.0, Encoding UTF-8*\* Definitions created/modified 2022-03-15 18:32*\* Field descriptions for each column entry:*\* 1 Name\* 2 Data Type\* 3 External Length\* 4 Fetch Offset\* 5 Scale\* 6 Level\* 7 Null\* 8 Bump if Odd\* 9 Internal Length\* 10 Binary Length\* 11 Table Length\* 12 Most Significant DT\* 13 Least Significant DT\* 14 High Precision\* 15 Low Precision\* 16 Elementary Item\* 17 Occurs\* 18 Key Column\* 19 Sub Data Type*Database type: ORACLECharacter set ID: UTF-8National character set ID: UTF-16Locale: neutralCase sensitivity: 14 14 14 14 14 14 14 14 14 14 14 14 11 1414 14*Definition for table POSTGRES.GGTESTRecord length: 262Syskey: 0Columns: 2COL1 64 50 1 50 50 50 1 1 2COL2 64 200 56 1 200 200 00 1 End of definition

后,将定义文件从oracle服务器/dirdef/KUNLUNTEST.def复制到kunlundb 服务器的./dirdef/KUNLUNTEST.def。



六、配置复制进程


在源端的抽取进程将数据的变更日志写入到trail日志中,日志可以通过dump进程或其他方式传输到目标端的OGG。复制进程将日志应用 KunlunBase  中去。


复制进程名称是rpor, 配置复制进程参数:

GGSCI (TARGET.KUNLUN.COM) 1> edit param rpor
with the parameters:
REPLICAT rporSOURCEDEFS ./dirdef/GGTEST.defSETENV ( PGCLIENTENCODING = "UTF8" )SETENV (ODBCINI="/var/kunlun/ggs/odbc.ini" )SETENV (NLS_LANG="AMERICAN_AMERICA.AL32UTF8")TARGETDB GG_Postgres, USERID kunlun, PASSWORD kunlunDISCARDFILE ./dirrpt/diskg.dsc, purgeMAP POSTGRES.GGTEST, TARGET public.kunluntest, COLMAP(COL1=col1,COL2=col2);

创建并启动复制进程。

GGSCI (ZKUPCHV119) 2> add replicat rpor, NODBCHECKPOINT,exttrail ./dirdat/epREPLICAT added.GGSCI (edvmr1p0) 3> start rpor
Sending START request to MANAGER ...REPLICAT REPKG starting
GGSCI (TARGET.KUNLUN.COM) 2> info allProgram Status Group Lag at Chkpt Time Since ChkptMANAGER RUNNINGREPLICAT RUNNING RPOR 00:00:00 00:00:07

 

复制配置完成。



七、测试


源库插入数据:

SQL> insert into KUNLUNTEST values (1,'hello world!');
1 row created.
SQL> commit;
Commit complete.
目标库查看数据同步结果
-bash-3.2$ psql KUNLUNTESTType "help" for help.
KUNLUNTEST=# select * from kunluntest; col1 | col2------+--------- 10 | hello world!
(1 rows)


目标库查看数据同步结果。

$ psql -h 192.168..130 -p 5401 -Uabc kunluntestType "help" for help.
KUNLUNTEST=# select * from kunluntest; col1 | col2------+--------- 10 | hello world!
(1 rows)



八、说明


OGG on  KunlunBase  的更详细的配置说明及压力测试请参考《 KunlunBase   快速入门(三)数据导入&同步

 

OGG ON  KunlunBase  数据同步原理请参考《异构数据同步-Postgresql中国技术大会0109v4.pdf - 墨天轮文档 (modb.pro)》(点击下方“阅读原文”)

点击阅读原文

推荐阅读

KunlunBase架构介绍
KunlunBase技术优势介绍
KunlunBase技术特点介绍
KunlunBase集群基本概念介绍

END

昆仑数据库是一个HTAP NewSQL分布式数据库管理系统,可以满足用户对海量关系数据的存储管理和利用的全方位需求。
应用开发者和DBA的使用昆仑数据库的体验与单机MySQL和单机PostgreSQL几乎完全相同,因为首先昆仑数据库支持PostgreSQL和MySQL双协议,支持标准SQL:2011的 DML 语法和功能以及PostgreSQL和MySQL对标准 SQL的扩展。同时,昆仑数据库集群支持水平弹性扩容,数据自动拆分,分布式事务处理和分布式查询处理,健壮的容错容灾能力,完善直观的监测分析告警能力,集群数据备份和恢复等 常用的DBA 数据管理和操作。所有这些功能无需任何应用系统侧的编码工作,也无需DBA人工介入,不停服不影响业务正常运行。
昆仑数据库具备全面的OLAP 数据分析能力,通过了TPC-H和TPC-DS标准测试集,可以实时分析新的业务数据,帮助用户发掘出数据的价值。昆仑数据库支持公有云和私有云环境的部署,可以与docker,k8s等云基础设施无缝协作,可以轻松搭建云数据库服务。
请访问 http://www.kunlunbase.com/ 获取更多信息并且下载昆仑数据库软件、文档和资料。
KunlunBase项目已开源
【GitHub:】
https://github.com/zettadb
【Gitee:】
https://gitee.com/zettadb

相关文章