1818IP-服务器技术教程,云服务器评测推荐,服务器系统排错处理,环境搭建,攻击防护等

当前位置:首页 - 数据库 - 正文

君子好学,自强不息!

以下的文章主要是介绍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.

altersystemsetglobal_names=truescope=both;

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

CREATEUSERCQMIDENTIFIEDBYCQMDEFAULTTABLESPACECQMTEMPORARYTABLESPACETEMP; 
GRANTDBATOCQM; 

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

创建repadmin用户管理Oracle高级复制环境

CREATEUSERREPADMINIDENTIFIEDBYREPADMIN; 
ALTERUSERREPADMINDEFAULTTABLESPACEUSERS; 
ALTERUSERREPADMINTEMPORARYTABLESPACETEMP; 
GRANTconnect,resourceTOREPADMIN; 

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

EXECUTEdbms_repcat_admin.grant_admin_any_schema('REPADMIN');

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

GRANTcommentanytableTOREPADMIN; 
GRANTlockanytableTOREPADMIN; 

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

EXECUTEdbms_defer_sys.register_propagator('REPADMIN'); 
GRANTexecuteanyprocedureTOREPADMIN; 

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

alterdatabaserenameglobal_nametoA.TEST.COM.CN; 
alterdatabaserenameglobal_nametoB.TEST.COM.CN; 

A:eread.im.com.cn

B:test.im.com.cn

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

createpublicdatabaselinktest.im.com.cnconnecttoREPADMINidentifiedbyREPADMINusing'test'; 
createpublicdatabaselinkeread.im.com.cnconnecttoREPADMINidentifiedbyREPADMINusing'eread'; 

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

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

CREATETABLETEST(IDNUMBER(10),TIMESTAMPDATEDEFAULTsysdate); 
ALTERTABLETESTADD(CONSTRAINTTEST_PKPRIMARYKEY(ID));

在数据库EREAD上用户CQM下:

CREATETABLETEST(IDNUMBER(10),TIMESTAMPDATEDEFAULTsysdate); 
ALTERTABLETESTADD(CONSTRAINTTEST_PKPRIMARYKEY(ID));

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

以REPADMIN登录数据库eread

创建复制组:

executedbms_repcat.create_master_repgroup('rep_hh'); 
executedbms_repcat.create_master_repgroup('repg');

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

executedbms_repcat.create_master_repobject(sname=>

'cqm',oname=>'test',type=>'table',

use_existing_object=>true,gname=>'repg');,copy_rows=>false);

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

executedbms_repcat.generate_replication_support('cqm','test','table');

添加主体复制节点:

executedbms_repcat.add_master_database

(gname=>'repg',master=>'test.im.com.cn',

use_existing_objects=>true,copy_rows=>false,propagation_mode=>'synchronous');

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

executedbms_repcat.resume_master_activity('repg',true);

八.至此配置完成

测试:

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

2)模拟大数据量测试:

CREATEORREPLACEprocedureinsert_into_test 
as 
inumber; 
mNUMBER; 
nNUMBER; 
BEGIN 
n:=0; 
FORiIN1..10000LOOP 
m:=i; 
INSERTINTOtest(id)VALUES(m); 
nn:=n+1; 
IFn=1000THEN 
COMMIT; 
n:=0; 
ENDIF; 
ENDLOOP; 
COMMIT; 
END; 
/

本文来源:1818IP

本文地址:https://www.1818ip.com/post/11164.html

免责声明:本文由用户上传,如有侵权请联系删除!

发表评论

必填

选填

选填

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。