Oracle GoldenGate日常运维过程中常见的问题

一、背景:

在工作,有用到oracle数据库,并且采用了RAC集群模式,但是存在两个oracle数据库之间需要同步指定表的数据,这里就使用到了goldengate,简称是ogg。

1、OGG简介

GoldenGate是一家创建于1995年的美国公司,开发总部设在旧金山,在北美,欧洲和亚洲(包括新加坡、印度、澳大利亚)设有支持中心。

GoldenGate公司专注于数据同步领域,是实现数据同步技术的领导者。至2007年,在全球35个国家售出超过2000个许可证,客户分布在政府、银行、电信、证券、传媒、医疗等行业,大部分客户为全球500强企业,如中国海关总署、中国国家体育总局体彩管理中心、中国电子口岸、海南移动、美国银行、VISA、瑞银集团、澳大利亚海关、新加坡港务局等。 GoldenGate是许多一流的数据库厂商如Oracle、Sybase、Microsoft、MySQL、Teradata等公司的认证合作伙伴,并且和著名的公司如HP、IBM、Sun等厂商建立了战略合作伙伴关系。

2009年被甲骨文Oracle公司收购。

2、GoldenGate 工作原理:

OGG提供了一个单一的平台,这个平台可以为任何企业环境实现秒一级的灾难备份。OGG是一种基于于日志的结构化数据复制方式,它通过解析源数据库在线日志或归档日志获得数据的增删改变化,再将这些变化应用到目标数据库,实现源数据库与目标数据库同步、双活。

机制原理图:

二、常见问题:

问题一:停止了ogg后,完成数据迁移后,启动ogg时报错

问题描述:

报错内容:

bash 复制代码
Wildcard MAP resolved (entry CAM*DBO.*):
MAP "CAM*DBO"."PSNSDATALOG", TARGET CAM*DBO."PSNSDATALOG";
Using following columns in default map by name:
IDATALOGID, SFILENAME, TSDOWNLOADED, ICOUNT
Using the following key columns for target table CAM*DBO.PSNSDATALOG: IDATALOGID.
 
2019-03-30 12:32:18 WARNING OGG-00869 OCI Error ORA-00001: unique constraint (CAM*DBO.PSNSDATALOG_ID) violated (status = 1). INSERT /*+ RESTRICT_ALL_REF_CONS */ INTO "CAM*DBO"."PSNSDATALOG " ("IDATALOGID","SFILENAME","TSDOWNLOADED","ICOUNT") VALUES (:a0,:a1,:a2,:a3).
 
2019-03-30 12:32:18 WARNING OGG-01004 Aborted grouped transaction on 'CAM*DBO.PSNSDATALOG', Database error 1 (OCI Error ORA-00001: unique constraint (CAM*DBO.PSNSDATALOG_ID) violated (status = 1). INSERT /*+ RESTRICT_ALL_REF_CONS */ INTO "CAM*DBO"."PSNSDATALOG" ("IDATALOGID","SFILENAME","TSDOWNLOADED","ICOUNT") VALUES (:a0,:a1,:a2,:a3)).
 
2019-03-30 12:32:18 WARNING OGG-01003 Repositioning to rba 71736862 in seqno 1967.
 
2019-03-30 12:32:18 WARNING OGG-01154 SQL error 1 mapping CAM*DBO.PSNSDATALOG to CAM*DBO.PSNSDATALOG OCI Error ORA-00001: unique constraint (CAM*DBO.PSNSDATALOG_ID) violated (status = 1). INSERT /*+ RESTRICT_ALL_REF_CONS */ INTO "CAM*DBO"."PSNSDATALOG" ("IDATALOGID","SFILENAME","TSDOWNLOADED","ICOUNT") VALUES (:a0,:a1,:a2,:a3).
 
2019-03-30 12:32:18 WARNING OGG-01003 Repositioning to rba 71736862 in seqno 1967.
 
2019-03-30 12:32:18 ERROR OGG-01296 Error mapping from CAM*DBO.PSNSDATALOG to CAM*DBO.PSNSDATALOG.

问题分析:

这个"表上有一个唯一的索引,用于生成PKFKPC_DI的字段。"这意味着有一个独特的限制。如果表本身没有约束,这并不重要。如果您构建的索引是唯一的,则如果存在重复,则无法插入该索引。

将有一个丢弃文件,您可以使用sqlplus从丢弃文件中的值手动插入此表。您将得到0001错误和复制。获取创建脚本或检查此表上的外部约束。

简单的来说就是主键的唯一约束和索引的唯一约束发生了冲突,在ogg抽取过来到目标的端的时候ogg识别不了哪一个是唯一约束条件,就造成了唯一约束的报错,只要在目标端指定唯一主键约束就可以了,

问题解决:

只要在复制进程中设置哪一个是唯一约束条件就可以了,是设置主键为唯一约束,

在复制进程配置文件中加入keycols(unique)可以了

例子:

sql 复制代码
MAP SF_HX.*,TARGET SF_CXTJ.*, colmap (usedefaults , sjtb_sj=@date ("yyyy-mm-dd hh:mi:ss.ffffff", "JTS", @GETENV("JULIANTIMESTAMP"))) keycols(RKFKPC_ID); 

然后启动复制进程就可以了,

> start rhx2cx07

> info all -------------发现复制进程起来了,

问题二:OGG链路源端与目标端版本不同(OGG-01669)

问题描述:

目标端不能读取数据复制链路报错

bash 复制代码
2019-04-07 23:56:21 INFO OGG-01669 Oracle GoldenGate Collector: Opening ./dirdat/ab000000 (byte -1, current EOF 0).
2012-08-08 00:00:25 ERROR OGG-01389 Oracle GoldenGate Delivery for Oracle, REP.prm: File header failed to parse tokens. File ./dirdat/aa000000, last offset 810, data: 0x 32A: 000000013A00000200003B000004000000013C000014000000101414141414141414141414141114141433000070300000070005455854444131000002000332000002000B3300000200023400000200013500000200003600000200013700003D003B56657273696F6E2031312E322E312E302E31204F4747434F52455F3131.
2012-08-08 00:00:25 ERROR OGG-01668 Oracle GoldenGate Delivery for Oracle, REP.prm: PROCESS ABENDING.

问题分析:

由于使用goldengate软件版本不同,源端版本高,目标版本低导致

问题解决:

解决方法: 在源端传输进程添加如下的内容

bash 复制代码
> edit param phn2cx
.......
RMTTRAIL ./dirdat/ba ,format release 11.1(版本号)

> alter extract ehn2cx, etrollover        ---------前滚生产新的trail文件
> start ehn2cx

注:有传输进程报错无法打开读取trail文件,查看是不是打开的对应trail文件和抽取的开始的trail文件对不上,

可以查看进程的运行报告得知,view report ehn2cx/phn2cx

-----重置传输的trail文件就可以了

bash 复制代码
> alter extract phn2cx,extseqno 1,extrba 0
> start phn2cx 

复制进程也重置读取的trail文件

bash 复制代码
> alter replicat rhn2cx,extseqno 1,extrba 0
> start rhn2cx

但是有时候添加了以后是行不通的,还是报OGG-01669问题,可以如下的操作

bash 复制代码
> edit param ehn2cx
........
EXTTRAIL ./dirdat/ab,format release 11.1

其他的操作和上面一样的,

相关推荐
齐 飞21 分钟前
MongoDB笔记01-概念与安装
前端·数据库·笔记·后端·mongodb
云空22 分钟前
《Python 与 SQLite:强大的数据库组合》
数据库·python·sqlite
暮毅27 分钟前
10.Node.js连接MongoDb
数据库·mongodb·node.js
wowocpp30 分钟前
ubuntu 22.04 server 格式化 磁盘 为 ext4 并 自动挂载 LTS
服务器·数据库·ubuntu
成富1 小时前
文本转SQL(Text-to-SQL),场景介绍与 Spring AI 实现
数据库·人工智能·sql·spring·oracle
songqq271 小时前
SQL题:使用hive查询各类型专利top 10申请人,以及对应的专利申请数
数据库·sql
计算机学长felix1 小时前
基于SpringBoot的“校园交友网站”的设计与实现(源码+数据库+文档+PPT)
数据库·spring boot·毕业设计·交友
小码的头发丝、2 小时前
Django中ListView 和 DetailView类的区别
数据库·python·django
Karoku0662 小时前
【企业级分布式系统】Zabbix监控系统与部署安装
运维·服务器·数据库·redis·mysql·zabbix
周全全2 小时前
MySQL报错解决:The user specified as a definer (‘root‘@‘%‘) does not exist
android·数据库·mysql