博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
异构GoldenGate 12c 单向复制配置
阅读量:7124 次
发布时间:2019-06-28

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

1.分别在windows2008、linux平台部署oracle 11.2.0.42.分别在windows2008、linux平台部署gg。    2.1 windows平台:            gg的安装目录位            C:\ora11g\product\ogg_src                        需设置环境变量 ORACLE_HOME and ORACLE_SID                 2.2 linux平台:            gg的安装目录位              [oracle@Oracle02 ~]$ ls -l /u01/app/oracle/product/            drwxrwxr-x.  3 oracle oinstall 4096 12月 13 10:21 11.2.0            drwxr-xr-x. 26 oracle oinstall 4096 12月 13 11:24 ogg_src            [oracle@Oracle02 ~]$                         需设置环境变量 export LD_LIBRARY_PATH=$ORACLE_HOME/lib            需要安装readline-devel-6.0-4.el6.x86_64.rpm(在linux平台 )            3.启动ogg的mgr管理进程,source和target端做相同的操作    3.1 启动wind的ogg的mgr        C:\ora11g\product\ogg_src>ggsci.exe        GGSCI (WIN-GM5PVS1CILH) 1> start mgr        Manager started.        GGSCI (WIN-GM5PVS1CILH) 2> info mgr        Manager is running (IP port WIN-GM5PVS1CILH.7809, Process ID 232).        3.2 启动linux的ogg的mgr                [oracle@Oracle02 product]$ cd ogg_src        [oracle@Oracle02 ogg_src]$ ./ggsci        GGSCI (Oracle02) 1> start mgr        MGR is already running.        GGSCI (Oracle02) 2> info mgr        Manager is running (IP port Oracle02.7809, Process ID 21213).        GGSCI (Oracle02) 3>            4准备工作,在source和target端都配置     4.1配置tnsnames.ora文件                orcl_w =          (DESCRIPTION =            (ADDRESS_LIST =              (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.100)(PORT = 1521))            )            (CONNECT_DATA =              (SID =orcl )            )          )        orcl_L =          (DESCRIPTION =            (ADDRESS_LIST =              (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.21)(PORT = 1521))            )            (CONNECT_DATA =              (SID =orcl )            )          )                    4.2 调整数据库        #确定数据库运行在归档模式,,        SQL> archive log list;        Database log mode              Archive Mode        Automatic archival             Enabled        Archive destination            USE_DB_RECOVERY_FILE_DEST        Oldest online log sequence     2        Next log sequence to archive   4        Current log sequence           4                #开启数据库附加日志        SQL> select supplemental_log_data_min from v$database;         SUPPLEME        --------        NO        SQL> alter database add supplemental log data;                SQL> select supplemental_log_data_min from v$database;         SUPPLEME        --------        YES                #打开force logging        SQL> alter database force logging;        SQL>         4.3 创建单独用于复制的数据库账号        SQL> create tablespace tbs_ogg;         SQL> create user ggs identified by ggs default tablespace tbs_ogg temporary tablespace temp account unlock;         SQL> grant connect,resource to ggs;        SQL> grant select any table to ggs;        SQL> grant select any dictionary to ggs;                SQL> create tablespace tbs_ogg;        SQL> create user ggt identified by ggt default tablespace tbs_ogg temporary tablespace temp account unlock;         SQL> grant connect,resource to ggt;        SQL> grant select any table to ggt;        SQL> grant select any dictionary to ggt;        SQL>            5.准备测试用户和表        SQL> alter user scott identified by scott account unlock;    SQL> grant connect,resource,select_catalog_role to scott;    SQL>             SQL> conn scott/scott    SQL> create table t1 as select * from dba_objects;            SQL> alter table t1 add constraint pk_t1 primary key(object_id);        SQL> select count(*) from t1; //source端      COUNT(*)    ----------         86045    SQL>                SQL> select count(*) from t1; //target端,只复制表定义,不填充数据      COUNT(*)    ----------             0    SQL>    6.初始化加载数据  注:在异构数据库平台,这个功能显得非常的有用!而在oracle-oracle的数据复制条件下,oracle推荐使用expdp/impdp工具    6.1 source端添加extract进程        GGSCI (WIN-GM5PVS1CILH) 2> info mgr        Manager is running (IP port WIN-GM5PVS1CILH.7809, Process ID 232).                GGSCI (WIN-GM5PVS1CILH) 3> add extract einig1,sourceistable  //sourceistable代表直接从表中读取数据        EXTRACT added.        GGSCI (WIN-GM5PVS1CILH) 4> edit params einig1                //einig1代表extract initial load group 1缩写                GGSCI (WIN-GM5PVS1CILH) 5> view params einig1                //查看设置后的参数        extract einig1        setenv (NLS_LANG=AMERICAN_AMERICA.ZHS16GBK)        userid ggs,password ggs        rmthost 192.168.0.21,mgrport 7809        rmttask replicat,group rinig1        table scott.t1;        GGSCI (WIN-GM5PVS1CILH) 6>        6.2 target端添加replicat进程        GGSCI (Oracle02) 2> info mgr        Manager is running (IP port Oracle02.7809, Process ID 21213).        GGSCI (Oracle02) 3> add replicat rinig1,specialrun         //rinig1代表replicat initial load group 1缩写          REPLICAT added.        GGSCI (Oracle02) 4> edit params rinig1                       //rinig1的名字必须同source端定义的group名字相同          GGSCI (Oracle02) 5> view params rinig1                     //查看设置后的参数        replicat rinig1          setenv (NLS_LANG=AMERICAN_AMERICA.ZHS16GBK)          assumetargetdefs          userid ggt,password ggt          discardfile ./dirrpt/rinig1.dsc,purge          map scott.*,target scott.*;        GGSCI (Oracle02) 6>     6.3.source端启动extract进程,查看日志输出            GGSCI (WIN-GM5PVS1CILH) 6> start extract einig1        Sending START request to MANAGER ...        EXTRACT EINIG1 starting        GGSCI (WIN-GM5PVS1CILH) 7>        6.4 target端验证                SQL> conn scott/scott        Connected.        SQL> select count(*) from t1;          COUNT(*)        ----------             81000        SQL>                 在这期间碰到几个坑,详见《OGG初始化加载数据时遇到的问题汇总》7.配置wind,linux间的实时同步复制    7.1 在source上配置extract进程,进程的名字不能超过8个字符            GGSCI (WIN-GM5PVS1CILH) 2> edit params eora_t1        GGSCI (WIN-GM5PVS1CILH) 3> view params eora_t1        extract eora_t1        setenv (NLS_LANG=AMERICAN_AMERICA.ZHS16GBK)        userid ggs@orcl_w,password ggs        exttrail dirdat/sp        table scott.*;        GGSCI (WIN-GM5PVS1CILH) 4>        7.2 开启scott用户下所有表的附加日志 (前面已经开始了数据库的附加日志,此处应该可以省略)                GGSCI (WIN-GM5PVS1CILH) 4> dblogin userid ggs, password ggs        Successfully logged into database.        GGSCI (WIN-GM5PVS1CILH as ggs@orcl) 5> add trandata scott.*            7.3 添加extract进程,添加trail文件,文件名前缀不能超过2个字符                    GGSCI (WIN-GM5PVS1CILH) 1> add extract eora_t1,tranlog,begin now        EXTRACT added.        GGSCI (WIN-GM5PVS1CILH) 2> add exttrail dirdat/sp,extract eora_t1,megabytes 100        EXTTRAIL added.        GGSCI (WIN-GM5PVS1CILH) 6> start extract eora_t1        Sending START request to MANAGER ...        EXTRACT EORA_T1 starting        GGSCI (WIN-GM5PVS1CILH) 7>        7.4:添加pump进程                GGSCI (WIN-GM5PVS1CILH) 2> edit params pora_t1        GGSCI (WIN-GM5PVS1CILH) 3> view params pora_t1        extract pora_t1        setenv (NLS_LANG=AMERICAN_AMERICA.ZHS16GBK)        passthru        rmthost 192.168.0.21,mgrport 7809        rmttrail dirdat/rp        table scott.*;        GGSCI (WIN-GM5PVS1CILH) 4>            GGSCI (WIN-GM5PVS1CILH) 1> add extract pora_t1,exttrailsource dirdat/sp   //这里sp文件名同前面extract进程参数文件中定义的trail文件名一致                EXTRACT added.        GGSCI (WIN-GM5PVS1CILH) 2>                    GGSCI (WIN-GM5PVS1CILH) 3> add rmttrail dirdat/rp,extract pora_t1,megabytes 100 //这里rp文件名同前面pora_t1进程参数文件中定义的trail文件名一致        RMTTRAIL added.        GGSCI (WIN-GM5PVS1CILH) 4>                GGSCI (WIN-GM5PVS1CILH) 5> start extract pora_t1        Sending START request to MANAGER ...        EXTRACT PORA_T1 starting        GGSCI (WIN-GM5PVS1CILH) 6> info all        Program     Status      Group       Lag at Chkpt  Time Since Chkpt        MANAGER     RUNNING        EXTRACT     RUNNING     EORA_T1     00:00:00      00:00:07        EXTRACT     RUNNING     PORA_T1     00:00:00      00:00:00        GGSCI (WIN-GM5PVS1CILH) 7>                7.5 在target端添加检查表,配置replicat进程            GGSCI (Oracle02) 5> edit params ./GLOBALS          checkpointtable ggt.chkpt        GGSCI (Oracle02 as ggt@orcl) 2> add checkpointtable        No checkpoint table specified. Using GLOBALS specification (ggt.chkpt)...        Successfully created checkpoint table ggt.chkpt.        GGSCI (Oracle02 as ggt@orcl) 3>                    SQL> select tname from tab;        TNAME        ------------------------------        CHKPT        CHKPT_LOX        SQL>                 #配置replicat进程        GGSCI (Oracle02 as ggt@orcl) 3> edit params rora_t1        GGSCI (Oracle02 as ggt@orcl) 4> view params rora_t1          replicat rora_t1          setenv (NLS_LANG=AMERICAN_AMERICA.ZHS16GBK)          userid ggt,password ggt          handlecollisions          assumetargetdefs          discardfile dirrpt/rora_t1.dsc,purge          map scott.* ,target scott.*;        GGSCI (Oracle02 as ggt@orcl) 5>                 GGSCI (Oracle02 as ggt@orcl) 5> add replicat rora_t1,exttrail dirdat/rp        REPLICAT added.        GGSCI (Oracle02 as ggt@orcl) 6>                        GGSCI (Oracle02 as ggt@orcl) 6> start replicat rora_t1        Sending START request to MANAGER ...        REPLICAT RORA_T1 starting        GGSCI (Oracle02 as ggt@orcl) 7>                GGSCI (Oracle02 as ggt@orcl) 7> info replicat rora_t1          REPLICAT   RORA_T1   Last Started 2016-12-13 17:26   Status RUNNING        Checkpoint Lag       00:00:00 (updated 00:00:00 ago)        Process ID           23078        Log Read Checkpoint  File dirdat/rp000000002                             2016-12-13 17:08:29.494703  RBA 1518        GGSCI (Oracle02 as ggt@orcl) 8>                    GGSCI (Oracle02 as ggt@orcl) 8> info all        Program     Status      Group       Lag at Chkpt  Time Since Chkpt        MANAGER     RUNNING                                                   REPLICAT    RUNNING     RORA_T1     00:00:00      00:00:01            GGSCI (Oracle02 as ggt@orcl) 9>     8.测试    8.1数据同步    C:\Users\Administrator>sqlplus scott/scott    连接到:    Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production    With the Partitioning, OLAP, Data Mining and Real Application Testing options    SQL> select max(object_id) from t1;    MAX(OBJECT_ID)    --------------             87135    SQL> desc t1;     名称                                      是否为空? 类型     ----------------------------------------- -------- ----------------------------     OWNER                                              VARCHAR2(30)     OBJECT_NAME                                        VARCHAR2(128)     SUBOBJECT_NAME                                     VARCHAR2(30)     OBJECT_ID                                 NOT NULL NUMBER     DATA_OBJECT_ID                                     NUMBER     OBJECT_TYPE                                        VARCHAR2(19)     CREATED                                            DATE     LAST_DDL_TIME                                      DATE     TIMESTAMP                                          VARCHAR2(19)     STATUS                                             VARCHAR2(7)     TEMPORARY                                          VARCHAR2(1)     GENERATED                                          VARCHAR2(1)     SECONDARY                                          VARCHAR2(1)     NAMESPACE                                          NUMBER     EDITION_NAME                                       VARCHAR2(30)    SQL> insert into t1 (object_id,object_name) values (87136,'ogg_test');    已创建 1 行。    SQL> commit;    提交完成。    SQL> conn scott/scott@orcl_L    已连接。    SQL> select max(object_id) from t1;    MAX(OBJECT_ID)    --------------             87136    SQL>            8.2 删除测试        SQL> conn scott/scott    已连接。    SQL> delete from t1 where object_id > 1000;    已删除85048行。    SQL> commit;    提交完成。    SQL> select max(object_id) from t1;    MAX(OBJECT_ID)    --------------              1000    SQL> conn scott/scott@orcl_L    已连接。    SQL>  select max(object_id) from t1;    MAX(OBJECT_ID)    --------------             87136

 

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

你可能感兴趣的文章
浅谈OpenStack与虚拟机的区别与联系
查看>>
Hive metastore整体代码分析及详解
查看>>
国际大牌背后的IT制胜秘诀
查看>>
渐进式Web应用(PWA)入门教程(上)
查看>>
MIUI 系统 BUG,Android 调用相机崩溃?将拍照适配方案进行到底!
查看>>
技术面试中常见的几道智力题 来看看你会做几道?
查看>>
前端常用功能记录(二)—datatables表格
查看>>
机器与人类的结合:外骨骼机器人的现状和趋势
查看>>
用Python进行机器学习(附代码、学习资源)
查看>>
微软发布 .NET for Apache Spark 首个预览版
查看>>
九州量子全球首个密钥云:让“一对多”模式成为可能
查看>>
Hmily 2.0.3 发布,高性能异步分布式事务 TCC 框架
查看>>
还在找什么,JavaScript的异步编程解决方案全在这里了
查看>>
iView 3.3.0 发布,基于 Vue.js 的企业级 UI 组件库
查看>>
如何使用表格存储控制台进行数据监控
查看>>
量子力学,在生命的世界里
查看>>
<xliff:g>标签
查看>>
BTA|杨耀东:打造一个支持百万级TPS的去中心化网络
查看>>
Linux PHP增加JSON支持及如何使用JSON
查看>>
首届数字中国建设峰会之“数字经济 · 闽江夜话”
查看>>