Oracle高级复制的同步相关复制8个步骤

以下的文章主要是介绍Oracle高级复制的同步相关复制,如果某个公司需要在全国几个相关的地方来架设服务器(Oracle)的话,就要求各个相关的DB数据的一致性,以下是测试方案中的一种:同步复制。

创新互联建站服务项目包括团风网站建设、团风网站制作、团风网页制作以及团风网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,团风网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到团风省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

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

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

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

一.数据库基本情况

数据库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用户管理Oracle高级复制环境

 
 
 
  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高级复制之同步复制的描述,希望会给你带来一些帮助在此方面。

【编辑推荐】

  1. Oracle常见问题的列举及解答
  2. 使用Oracle RMAN来进行基于表空间的恢复
  3. Oracle 9i强大功能的体现
  4. Oracle存储过程的编写经验总结
  5. 配置Oracle RAC中应注意的问题

名称栏目:Oracle高级复制的同步相关复制8个步骤
文章路径:http://www.shufengxianlan.com/qtweb/news4/401454.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联