基于Linux环境使用ogg19版本从oracle 19c ADG备库远程同步数据

基于Linux环境使用ogg19版本对oracle 19c同步数据

在之前一期文章中提到了 "基于Windows测试OGG远程从ADG备库抽取数据"。文章的最后提到了在Linux环境测试失败的情况,在这一期的文章中测试了Linux环境,但是使用的数据库版本和OGG版本均是19的。之前那一期的数据库版本是11.2.0.4 ,ogg版本是12.1.0.1。有可能是因为版本的问题导致。

此次案例测试中,数据可以成功抽取成功。

说明:代码有些部分对不上,是因为测试过程种来回切换,有些关键字也虚拟模糊了,步骤和方法是正确的。

静默安装OGG

复制代码
./runInstaller -silent -nowait -responseFile /so/fbo_ggs_Linux_x64_shiphome/Disk1/response/oggcore.rsp

数据库ADG搭建请翻阅前面的文章

链接: oracle 19c搭建dataguard(ADG)全过程

源端和目标端创建OGG同步用户

复制代码
源端(10.120.84.25)和目标端创建同步管理账号
--84.25

create tablespace tbsogg datafile '+DATA/xx/DATAFILE/tbsogg.dbf' size 1024m autoextend on next 10m;

--103.54
create tablespace tbsogg datafile 'D:\APP\ADMINISTRATOR\ORADATA\xxx\tbsogg01.dbf' size 1024m autoextend on next 10m;


create user ggs identified by xxx default tablespace tbsogg temporary tablespace temp;
grant connect ,resource,unlimited tablespace to ggs;
grant execute on utl_file to ggs;
grant select any dictionary,select any table to ggs;
grant alter any table to ggs;
grant flashback any table to ggs;
grant execute on dbms_flashback to ggs;
grant execute on sys.DBMS_STREAMS to ggs;
grant execute on dbms_xstream_gg_adm to ggs;
grant execute on DBMS_CAPTURE_ADM to ggs;
grant SELECT ANY TRANSACTION to ggs;
EXEC DBMS_GOLDENGATE_AUTH.GRANT_ADMIN_PRIVILEGE('ggs');
grant execute on sys.DBMS_STREAMS to ggs;
grant execute on dbms_xstream_gg_adm to ggs;
grant execute on dbms_streams_adm to ggs;
grant execute on DBMS_CAPTURE_ADM to ggs;
grant execute on dbms_xstream_gg_adm to ggs;
grant SELECT ANY TRANSACTION to ggs;

数据库连接串配置

复制代码
#primary
ORA104 =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.56.104)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = woo)
    )
  )

#standby
ORA105 =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.56.105)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = woo)
    )
  )

MGR进程配置

复制代码
port 5000
dynamicportlist 5001-5050
autorestart extract *,retries 5,waitminutes 3
purgeoldextracts ./dirdat/*, usecheckpoints,minkeepdays 3
accessrule, prog *, ipaddr *, allow
lagreporthours 1
laginfominutes 30
lagcriticalminutes 45

创建OGG登录别名

复制代码
--创建用户凭证别名
add credentialstore
--创建到源端的登录别名
--登录源端主库别名
alter credentialstore add user ggs@xxx, password Caecaodb2017 alias xx
alter credentialstore add user ggs@xxx, password Caecaodb2017 alias xx
alter credentialstore add user ggs@xxx, password Caecaodb2017 alias xxx

--登录源端备库别名
alter credentialstore add user ggs@xxx, password Caecaodb2017 alias xxx
alter credentialstore add user ggs@xxx, password Caecaodb2017 alias xxx
alter credentialstore add user ggs@xxx, password Caecaodb2017 alias xxx

--目标端登录别名
alter credentialstore add user ggs@xxx, password Caecaodb2017 alias xx

--测试验证
dblogin useridalias xxx

添加抽取进程

复制代码
add extract escims3, tranlog, begin now, threads 1    <<<<< 如果是RAC,修改为2
add exttrail ./dirdat/e3, extract escims3, megabytes 50

edit params escims3

extract escims3
SETENV (TNS_ADMIN='/app/oracle/product/19.3.000/db_home/network/admin')
userid ggs@ora105, password xxxx
exttrail ./dirdat/e3
discardfile ./dirrpt/escims3.dsc, append, megabytes 20
discardrollover at 05:30 on monday
warnlongtrans 3h, checkinterval 10m
tranlogoptions logretention enabled
tranlogoptions dblogreader
tranlogoptions minefromactivedg
--tables
table ggs.testtab;

添加应用进程(有些关键字做了虚拟)

复制代码
dblogin useridalias xxxx
add checkpointtable ggs.xxxx

--非并行进程
add replicat rs3t, exttrail ./dirdat/e3, checkpointtable ggs.xxxx

edit param rs3t

replicat rs3t
useridalias xxxx
discardfile ./dirrpt/rs3t.dsc, append, megabytes 100
discardrollover at 05:30 on monday
--tables
gettruncates
map ggs.testtab ,target maintain.testtab;

数据初始化的方式有2种

复制代码
>>>>> 数据初始化 数据泵初始化方式
SET NUMWIDTH 20;   
select current_scn from v$database;
12346555158664
expdp \"/ as sysdba\" dumpfile=testtabt320251103.dmp logfile=exptesttabt320251103.log exclude=statistics ggs.testtab flashback_scn=21870773

 (根据同步当时获取的值填写)

目标端 10.128.103.54 导入数据
impdp \"/ as sysdba\" dumpfile=testtabt320251103.dmp logfile=imptesttabt320251103.log remap_schema=ggs:testtab table_exists_action=truncate 



>>>>> 数据初始化 load init方式

add extract ext_init,sourceistable

参数配置
edit param ext_init

extract ext_init
SETENV (TNS_ADMIN='/OSdata/oraclient/instantclient_19_28/network/admin')
useridalias SCIMS8422
rmthost 10.128.255.146, mgrport 5000
rmttask replicat,group rep_init
table ggs.testtab;



add replicat rep_init,specialrun

edit param rep_init

replicat rep_init
useridalias tn_ncdb10338
assumetargetdefs
discardfile ./dirrpt/rep_init.dsc, append, megabytes 100
map ggs.testtab, target maintain.testtab;

测试数据

复制代码
GGSCI (ora19 as ggs@woo) 27> info all

Program     Status      Group       Lag at Chkpt  Time Since Chkpt

MANAGER     RUNNING                                           
EXTRACT     RUNNING     ESCIMS3     00:00:01      00:00:02    


GGSCI (ora19 as ggs@woo) 28> stats escims3,daily

Sending STATS request to EXTRACT ESCIMS3 ...

Start of Statistics at 2025-11-05 21:34:07.

Output to ./dirdat/e3:

Extracting from GGS.TESTTAB to GGS.TESTTAB:

*** Daily statistics since 2025-11-05 21:33:46 ***
        Total inserts                                      1.00
        Total updates                                      0.00
        Total deletes                                      0.00
        Total upserts                                      0.00
        Total discards                                     0.00
        Total operations                                   1.00

End of Statistics.


GGSCI (ora19 as ggs@woo) 29> info all

Program     Status      Group       Lag at Chkpt  Time Since Chkpt

MANAGER     RUNNING                                           
EXTRACT     RUNNING     ESCIMS3     00:00:00      00:00:09    
相关推荐
梅尔文.古10 小时前
RaspberryPi-如何启用看门狗
linux·运维·服务器
木子欢儿10 小时前
Ubuntu 24 安装 fcitx5 + rime + 雾凇配置
linux·运维·服务器·ubuntu
sg_knight10 小时前
Nuxt 4 生产环境部署指南 (Node.js + Nginx)
运维·nginx·node.js·nuxt·ssr
Alice10 小时前
linux scripts
java·linux·服务器
企微自动化10 小时前
自动化报表生成:将 RPA 采集的群聊数据自动整理为可视化周报
运维·自动化·rpa
代码游侠10 小时前
学习笔记——IPC(进程间通信)
linux·运维·网络·笔记·学习·算法
txzz888810 小时前
CentOS-Stream-10 YUM配置文件
linux·运维·centos·yum配置文件
星融元asterfusion10 小时前
办公网+自建云:基于TIP OpenWiFi 控制器的混合组网一站式融合管理方案
运维·混合组网·openwifi
Henry Zhu12310 小时前
VPP中ACL源码详解第二篇:ACL数据平面处理
运维·服务器·网络·计算机网络