您好,欢迎访问一九零五行业门户网

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

以下的文章主要讲述的是oracle高级复制的同步复制,如果你需要在全国的几个相关地方来架设相关服务器(oracle),其要求是各个相关的db数据的一致,以下就是具体方案的描述,希望在你今后的学习中会有所帮助。 以下是测试方案中的一种:同步复制 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.
alter system set global_names=true scope=both; 
二.在两个数据库上分别创建应用用户cqm
create user cqm identified by cqm default tablespace cqm temporary tablespace temp;  grant dba to cqm;  
三.在两个数据库上分别创建复制管事员用户repadmin
创建repadmin用户管理复制环境
create user repadmin identified by repadmin;   alter user repadmin default tablespace users;   alter user repadmin temporary tablespace temp;   grant connect, resource to repadmin;   
授予repadmin用户权限可以管理当前站点中任何主体组
execute dbms_repcat_admin.grant_admin_any_schema('repadmin');  
授予repadmin用户权限可以为任何表创建snapshot logs
grant comment any table to repadmin;   grant lock any table to repadmin;   
指定repadmin用户为propagator,并授予执行任何procedure的权限
execute dbms_defer_sys.register_propagator('repadmin');   grant execute any procedure to repadmin;   

四.更改两个数据库的全局名称
alter database rename global_name to a.test.com.cn;  alter database rename global_name to b.test.com.cn;  
a:eread.im.com.cn
b:test.im.com.cn
五.在两个数据库上建立数据库链接
create public database link test.im.com.cn connect to repadmin identified by repadmin using 'test';  create public database link eread.im.com.cn connect to repadmin identified by repadmin using 'eread';  
六.在两个数据库的应用用户cqm下创建表
在数据库eread上用户cqm下:注意,要进行oracle高级复制的表必须有主键
create table test(id number(10),timestamp date default sysdate);  alter table test add(constraint test_pk primary key(id)); 

在数据库eread上用户cqm下:
create table test(id number(10),timestamp date default sysdate);  alter table test add(constraint test_pk primary key(id)); 

七.在主体定义站点开始操作(数据库a:eread)
以repadmin登录数据库eread
创建复制组:
execute dbms_repcat.create_master_repgroup('rep_hh');   execute dbms_repcat.create_master_repgroup('repg');  
在复制组里加入复制对象:
execute dbms_repcat.create_master_repobject
(sname=>'cqm',oname=>'test',type=>'table',
use_existing_object=>true,gname=>'repg');,copy_rows=>false); 
对复制对象产生复制支持:
execute dbms_repcat.generate_replication_support('cqm','test','table'); 
添加主体复制节点:
execute dbms_repcat.add_master_database(gname=>'repg',master=>'
test.im.com.cn',use_existing_objects=>true,
copy_rows=>false, propagation_mode => 'synchronous');  
在主体定义站点启动oracle高级复制:
execute dbms_repcat.resume_master_activity('repg',true); 
八.至此配置完成
测试:
1)模拟小数据量测试:ok
2)模拟大数据量测试:
create or replace procedure insert_into_test  as  i number;  m number;  n number;  begin  n:=0;  for i in 1..10000 loop  m:=i;  insert into test(id)values (m);  nn:=n+1;  if n=1000 then  commit;  n:=0;  end if;  end loop;  commit;  end;  /  
以上的相关内容就是对oracle高级复制之同步复制的介绍,望你能有所收获。
其它类似信息

推荐信息