DDL复制的配置

  1. 目前只支持oracle和teradata的ddl复制
  2. oracle能复制除了系统对象之外的所有对象
  3. 两种配置方法:
    1. 基于trigger的DDL:对于生产库有一定影响。
      1. 原理:
        1. 源库建立一个oracle全库级别的trigger捕捉DDL操作到中间表。
        2. extract读取中间表的DDL语句并且与DML语句根据csn排序。
        3. 目标端重现该DDL操作sql语句。
      2. 特点:
        1. DDL和DML复制原理不同:
        2. DDL复制基于Trigger,DML复制基于日志,两者复制机理不同,它们之间的数据捕捉是没有联系的,只是在主extract进程中通过scn号按照发生的顺序进行组装,保证DDL操作和DML操作按照其原来的顺序执行。
        3. DDL和DML复制互相独立:DDL的复制Trigger建立之后,无论DML复制是否运行,该Trigger一直在发生作用,捕捉DDL的sql语句到中间表。因此,DML复制的启停并不影响DDL的捕获;DDL Trigger的启用和停止并不影响DML的复制,只是该Trigger被禁止后不再抓取DDL操作;DDL和DML之间除了在extract组装时靠scn排序产生次序关系,没有其它任何联系。
        4. DDL复制只是简单的sql复制。抓取sql扔到目标端重新执行一遍而已。
        5. 打开DDL复制能够自动创建每次补丁新建和修改的对象,并自动维护对于的附加日志,无需人工介入,减少人工工作量。
      3. 使用原则:
        1. 两端必须是oracle数据库:不支持standby db的ddl抽取。
        2. 支持双向复制DDL (只是支持2个节点)
        3. 两端表结构保持一致;(replicat:ASSUMETARGETDEFS)
        4. 不支持DDL transform(map和filter支持)
        5. DDL语句小于2M大小;
        6. pump进程不负责任任何map和filter,使用passthru
        7. 数据库每天的日子量不宜过大:100g以下;过大会影响性能。
        8. 应用系统在数据库中不能有频繁的DDL操作,在erp系统里面,如频繁建立中间表等操作,这个时候性能也被极大影响。
      4. 默认:
        1. 默认情况下:extract是关闭DDL的,而data pump进程和replicat默认是打开的。所以只需要在extract进程中配置DDL复制就可以了。但是建议在replicat中配置DDL相关属性;
        2. replicat进程默认是所有DDL都做复制,如果有多个replicat进程在跑,那必须在每个replicat进行配置,否则会引起重复复制。
        3. goldengate用户和oracle数据库自带的用户的DDL操作不会被复制。
        4. 当开启full ddl(all scope)支持时,不需要在参数文件中使用gettruncates参数。
      5. DDL复制范围界定:
        1. ALL:表示复制所有的DDL操作,所有源库产生的ddl都会被放到队列当中。
        2. MAPPED:表示只复制在后面所有table参数指定的表,所相关联的对象,如索引,列的变化等,如果要复制新建的表,那么这些表必须显示列在table语句里,或者符合table中使用匹配的条件。
        3. unmapped:表示只复制不在table范围内的表的相关的DDL。
        4. Other:该范围表示无关的DDL操作:例如对数据库本身,用户,表空间,数据文件的操作。一般实际中不使用。
        5. OPTYPE:操作类型:比如:create,alter
        6. OBJTYPE:对象范围:如table或index
        7. OBJNAME:对象名:
        8. INSTR:关键字的范围
      6. 实际例子
        DDL &
        INCLUDE MAPPED OBJTYPE 'table' & --$符号是转行符号,可以降低出错率。
        INCLUDE MAPPED OBJTYPE 'index'
        ddloptions addtrandata, nocrossrename
        table abc.* --为了降低出错率,建议只复制map范围内的表和索引等主要对象;
        --如果要复制新建表,该表必须在后面table指定范围内(一般用×)
        --trandata:自动更新附加日志,也可以用add schematrandata
        DDL [{INCLUDE | EXCLUDE}]
        [, MAPPED | UNMAPPED | OTHER | ALL]
        [, OPTYPE <type>]
        [, OBJNAME "<name>" ]
        [, INSTR '<string>' ]

      7. 基于trigger的几个小问题:
        1. 数据库(源库)如果是10g,一定需要关闭recycle bin。避免隐形的ddl的抽取,可能会出现两次的操作,11g以后不需要,原理改变。
        2. goldengate需要独立的表空间:不能共享。
        3. 执行ddl_setup.sql之前,需要明确授权:create table, create sequence,即使有DBA权限也不行。
        4. 大致步骤:marker_setup -- DDL setup -- role setup -- enable DDL trigger
      8. 几个特例说明:
        1. 和目标数据库一致性有关的测试:

          1. create job不支持
          2. create trigger是可以复制的,且enable状态,所以必须手工设置为disable或者replicat参数;
          3. create tablespace是可以复制的,可以支持复制到不同文件目录;
          4. CTAS语句的复制:最终结果按照本地的数据来(如:create table xx as select * from dba_objects;)
          5. rename t1 to t2 会被转换成alter table t1 rename to t2 (view report rep1)
          6. flashback table to scn ---可以支持复制
          7. flashback table to before drop --不支持复制
    2. Native DLL(通过logminer server进行日志解析 – ogg12c + integrated extract +db11204及以上):从日志里面进行解析。
      1. 版本要求:OGG12c, db11204,以上;compatible设置11.2.0.4或以上;downstream模式下,sourcedb也要满足以上要求。
      2. 集成抽取模式
      3. 参数不变

12c复制的新特性

truncate复制

sequence复制的配置

压缩配置

加密配置

TDE透明技术加密的列的抽取

golden gate的DDL配置的更多相关文章

  1. Oracle Golden Gate - 概念和机制 (ogg)

    Golden Gate(简称OGG)提供异构环境下交易数据的实时捕捉.变换.投递. OGG支持的异构环境有: OGG的特性: 对生产系统影响小:实时读取交易日志,以低资源占用实现大交易量数据实时复制 ...

  2. 转://Oracle Golden Gate 概念和原理

    引言:Oracle Golden Gate是Oracle旗下一款支持异构平台之间高级复制技术,是Oracle力推一种HA高可用产品,简称“OGG”,可以实现Active-Active 双业务中心架构 ...

  3. [转载]Oracle Golden Gate - 概念和机制 (ogg)

    出处:https://www.cnblogs.com/qiumingcheng/p/5435907.html Golden Gate(简称OGG)提供异构环境下交易数据的实时捕捉.变换.投递. OGG ...

  4. Oracle Golden Gate原理简介

    Oracle Golden Gate原理简介 http://www.askoracle.org/oracle/HighAvailability/20140109953.html#6545406-tsi ...

  5. Oracle Golden Gate概要

    Oracle GoldenGate简介 Oracle Golden Gate用于源数据库与目标数据库的数据复制备份:可以在异构的环境(各种操作系统和数据库)之间实现数据亚秒级的实时复制备份:以及可以在 ...

  6. Golden Gate 相关组件介绍:

    OGG组件: Manager: 启动其它进程 Collector Extract Data Pump:可选进程,建议使用 Replicat Trails: 可以压缩,加密 Checkpoint OGG ...

  7. Sybase to Oracle Golden Gate

    Sybase 安装Golden Gate: 下载,然后create subdirs.并且在两端配置好mgr,设置好端口7809 创建golden gate用户ogguser,并且给它授权sa和repl ...

  8. golden gate 加initial load 在rac 上的配置

    前言goldengate 11g 在oracle 11g rac 上的配置 (源是rac+asm , 目标是单数据库实例) 源端: 1. 配置tnsnames [oracle@rac1 admin]$ ...

  9. Oracle Golden Gate基本配置

    >> from zhuhaiqing.info [oracle@localhost ogg]$ cat ~/.bash_profile GG_HOME=/opt/oggPATH=$PATH ...

随机推荐

  1. (转)基于MVC4+EasyUI的Web开发框架形成之旅--附件上传组件uploadify的使用

    http://www.cnblogs.com/wuhuacong/p/3343967.html 大概一年前,我还在用Asp.NET开发一些行业管理系统的时候,就曾经使用这个组件作为文件的上传操作,在随 ...

  2. IOS Html富文本渲染方式:DTCoreText、WKWebView、UIWebView的内存占用对比

    在app的内容页(详情页)中,富文本的显示一直是经常需要处理的问题,而通常在后端的富文本编辑中,Html应用比较普遍,所以其实需要处理的Html富文本显示的问题,以下这三种方式肯定不是最优的显示Htm ...

  3. 使用序列号激活优动漫PAINT(附激活码)

    优动漫PAINT是一款功能强大的动漫绘图软件,简单的中文界面和丰富的笔刷操纵,再次为设计工作者带来非一般的感受!最近,有不少小伙伴提出这样的疑问:购买安装优动漫PAINT之后,不知道如何激活,在哪里输 ...

  4. 在小程序中实现全局混入,以混入的形式扩展小程序的api

    GitHub: https://github.com/WozHuang/mp-extend 相关文章: 小程序全局状态管理,在页面中获取globalData和使用globalSetData 通过页面预 ...

  5. JavaScript进阶【四】JavaScript中的this,apply,call的深入剖析

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. 小结ajax中的同源和跨域 jsonp和cors

    网上的同源和跨域一般都比较复杂,最近也稍微总结了一下: 所谓同源,是浏览器的一种安全机制,作用在于保护网页数据的安全,不同源的网页之间不允许cookie dom ajax等行为 同源的条件:1.协议相 ...

  7. Linux Shell脚本编程-基础1

    概述:  shell脚本在Linux系统管理员的运维工作中非常重要.shell脚本能够帮助我们很方便的管理服务器,因为我们可以指定一个任务计划,定时的去执行某一个脚本以满足我们的需求.本篇将从编程基础 ...

  8. docker 命令部分

    本文只记录docker命令在大部分情境下的使用,如果想了解每一个选项的细节,请参考官方文档,这里只作为自己以后的备忘记录下来. 根据自己的理解,总的来说分为以下几种: 看一个变迁图   看一个变迁图 ...

  9. ActiveMQ 整合 spring

    一.添加 jar 包 <dependency> <groupId>org.apache.activemq</groupId> <artifactId>a ...

  10. WebStorm 6.0 与 7.0 注册码

    经测试 WebStorm 7均可以使用如下注册码,简直就是神key啊! WebStorm 6.0 与 7.0 注册码 User Name: EMBRACE License Key: ===== LIC ...