博客
关于我
Oracle-OGG,双向同步过滤OGG自身用户的DML失效,如何处理?
阅读量:443 次
发布时间:2019-03-06

本文共 829 字,大约阅读时间需要 2 分钟。

一、问题与解决方案

在Oracle数据库的双向同步场景中,已发现OGG用户的DML操作未能被有效过滤,导致数据同步过程出现无限循环的情况。 为解决此问题,我们尝试通过调整传输选项参数来实现过滤。以下是具体操作步骤和验证结果。

2.1 参数调整:TRANLOGOPTIONS EXCLUDEUSER

在11g库中,我们尝试通过设置`TRANLOGOPTIONS EXCLUDEUSER ogg01`来过滤OGG用户的DML操作。然而,验证发现该参数在11g抽取进程中仍无法有效过滤OGG用户的插入操作。进一步分析发现,该参数在19c库中的应用效果较好,但11g库中仍存在数据同步问题。

2.2 参数调整:EXCLUDEUSERID

针对11g库中的问题,我们尝试将过滤参数从`EXCLUDEUSER`升级至`EXCLUDEUSERID`。具体做法是:在11g库中设置`TRANLOGOPTIONS EXCLUDEUSERID 84`,其中`84`为OGG用户的用户ID。通过这一调整,发现OGG用户的插入操作确实得到了有效过滤。

2.3 参数调整:EXCLUDETAG

此外,我们还尝试通过设置`DBOPTIONS SETTAG 1234`来实现过滤。对于19c库中的OGG用户,通过设置`TRANLOGOPTIONS EXCLUDETAG 1234`,能够有效过滤相关DML操作。验证结果表明,该参数在19c库中表现良好,且支持双向同步场景下的过滤需求。

总结

通过以上参数调整,我们成功实现了对OGG用户的DML操作过滤。具体做法包括: 1. 在11g库中,通过`TRANLOGOPTIONS EXCLUDEUSERID 84`实现过滤; 2. 在19c库中,通过`DBOPTIONS SETTAG 1234`和`TRANLOGOPTIONS EXCLUDETAG 1234`实现过滤。

这些调整有效解决了双向同步中的无限循环问题,确保了数据同步的稳定性。

转载地址:http://kllyz.baihongyu.com/

你可能感兴趣的文章
php取当天的最后一秒_Docker快速搭建PHP开发环境详细教程
查看>>
php取绝对值
查看>>
PHP变量内容的获取
查看>>
php各种常用的算法
查看>>
php各种缓存策略对比
查看>>
RabbitMQ高级特性 - 消息分发(限流、负载均衡)
查看>>
php后台“爬虫”模拟登录第三方系统
查看>>
php后台的在控制器中就可以实现阅读数增加
查看>>
php命令行生成项目结构
查看>>
php命名空间
查看>>
PHP命名空间带来的干扰
查看>>
PHP和MySQL Web开发从新手到高手,第1天-搭建PHP开发环境
查看>>
php商店管理系统,基于PHP的商店管理系统.doc
查看>>
PHP四大主流框架的优缺点总结
查看>>
PHP图片处理—PNG透明缩放并生成灰图
查看>>
php在liunx系统中设置777权限不起作用解决方法
查看>>
PHP基于openssl实现的非对称加密操作
查看>>
php基本符号大全
查看>>
php基础篇-二维数组排序 array_multisort
查看>>
php基础配置环境变量
查看>>