goldengate–使用filter+@GETENV在线重新初始化指定的table
在oracle-oracle goldengate的复制环境中,有时候会碰到一些紧急的问题一时无法修复,为了避免影响整个复制环境的复制进度,采取跳过错误事务或者跳过特定对象的办法使得goldengate继续同步;如果后续某个表不得不需要重新同步,而且应用是不间断进行事务操作的,在不停止应用和重建整个复制环境的情况下,为了保证数据的一致性,如何在线对特定的问题对象重新初始化和继续同步呢?
处理的办法还是不少的,下面给出一个在replicat端过滤SCN事务的办法,来实现数据的一致同步。
处理的思路就是首先在target上获得该表上某个特定SCN版本上的数据(比如使用导入导出或者数据泵),然后通过filter功能来筛选出该表上大于该commit scn的事务,从而确保事务的一致性。在goldengate v10之后,可以通过@GETENV函数直接获得事务的CSN。
