Oracle高级复制的同步复制的配置步骤说明


  本文标签:Oracle高级复制

  以下的文章主要讲述的是Oracle高级复制的同步复制,如果你需要在全国的几个相关地方来架设相关服务器(Oracle),其要求是各个相关的DB数据的一致,以下就是具体方案的描述,希望在你今后的学习中会有所帮助  。

  以下是测试方案中的一种:同步复制

  Oracle 高级复制同步复制配置步骤详细说明

  [Oracle] Oracle高级复制同步复制配置步骤

  首先,数据库要具备Oracle高级复制功能(用system身份登录数据库,查看v$option视图,如果其中Advanced replication为TRUE,则支持高级复制功能;否则不支持)

  一.数据库基本情况

  数据库A 版本Oracle 10.2.0.1 数据库名sid:eread

  数据库B 版本Oracle 10.1.0.3 数据库名sid:test

  主体定义站点:A eread

  主体站点:B test

  注:主体定义站点指配置复制工作的站点

  本例涉及的用户.

  复制管理员:repadmin

  应用用户:cqm

  本例Oracle高级复制的对象:reptest 数据表

  本例的先决条件:你需要设置好相应的参数,job_queue_processes需要大于0,global_name=true,并且建立相应的db link.

  

  1. alter system set global_names=true scope=both

  二.在两个数据库上分别创建应用用户CQM

  

  1. CREATE USER CQM IDENTIFIED BY CQM DEFAULT TABLESPACE CQM TEMPORARY TABLESPACE TEMP;  
  2. GRANT DBA TO CQM;  

  

  三.在两个数据库上分别创建复制管事员用户REPADMIN

  创建repadmin用户管理复制环境

  

  1. CREATE USER REPADMIN IDENTIFIED BY REPADMIN;   
  2. ALTER USER REPADMIN DEFAULT TABLESPACE USERS;   
  3. ALTER USER REPADMIN TEMPORARY TABLESPACE TEMP;   
  4. GRANT connect, resource TO REPADMIN;   

  

  授予repadmin用户权限可以管理当前站点中任何主体组

  

  1. EXECUTE dbms_repcat_admin.grant_admin_any_schema(REPADMIN);  

  授予repadmin用户权限可以为任何表创建snapshot logs

  

  1. GRANT comment any table TO REPADMIN;   
  2. GRANT lock any table TO REPADMIN;   

  

  指定repadmin用户为propagator,并授予执行任何procedure的权限

  

  1. EXECUTE dbms_defer_sys.register_propagator(REPADMIN);   
  2. GRANT execute any procedure TO REPADMIN;   

  

  

  四.更改两个数据库的全局名称

  1. alter database rename global_name to A.TEST.COM.CN;  
  2. alter database rename global_name to B.TEST.COM.CN;  

  A:eread.im.com.cn

  B:test.im.com.cn

  五.在两个数据库上建立数据库链接

  

  1. create public database link test.im.com.cn connect to REPADMIN identified by REPADMIN using test;  
  2. create public database link eread.im.com.cn connect to REPADMIN identified by REPADMIN using eread;  

  

  六.在两个数据库的应用用户CQM下创建表

  在数据库EREAD上用户CQM下:注意,要进行Oracle高级复制的表必须有主键

  

  1. CREATE TABLE TEST(ID NUMBER(10),TIMESTAMP DATE DEFAULT sysdate);  
  2. ALTER TABLE TEST ADD(CONSTRAINT TEST_PK PRIMARY KEY(ID)); 

  在数据库EREAD上用户CQM下:

  

  1. CREATE TABLE TEST(ID NUMBER(10),TIMESTAMP DATE DEFAULT sysdate);  
  2. ALTER TABLE TEST ADD(CONSTRAINT TEST_PK PRIMARY KEY(ID)); 

  七.在主体定义站点开始操作(数据库A:eread)

  以REPADMIN登录数据库eread

  创建复制组:

  

  1. execute dbms_repcat.create_master_repgroup(rep_hh);   
  2. execute dbms_repcat.create_master_repgroup(repg);  

  在复制组里加入复制对象:

  

  1. execute dbms_repcat.create_master_repobject
    (
    sname=>cqm,oname=>test,type=>table,
    use_existing_object=>true,gname=>repg);,copy_rows=>false); 

  对复制对象产生复制支持:

  

  1. execute dbms_repcat.generate_replication_support(cqm,test,table); 

  添加主体复制节点:

  

  1. execute dbms_repcat.add_master_database(gname=>repg,master=>
    test.im.com.cn,
    use_existing_objects=>true,
    copy_rows=>false, propagation_mode => synchronous);  

  在主体定义站点启动Oracle高级复制:

  

  1. execute dbms_repcat.resume_master_activity(repg,true); 

  八.至此配置完成

  测试:

  1)模拟小数据量测试:OK

  2)模拟大数据量测试:

  

  1. CREATE OR REPLACE procedure insert_into_test  
  2. as  
  3. i number;  
  4. m NUMBER;  
  5. n NUMBER;  
  6. BEGIN  
  7. n:=0;  
  8. FOR i IN 1..10000 LOOP  
  9. m:=i;  
  10. INSERT INTO test(id)VALUES (m);  
  11. nn:=n+1;  
  12. IF n=1000 THEN  
  13. COMMIT;  
  14. n:=0;  
  15. END IF;  
  16. END LOOP;  
  17. COMMIT;  
  18. END;  
  19. /  

  以上的相关内容就是对Oracle高级复制之同步复制的介绍,望你能有所收获  。