日期:2014-05-16 浏览次数:20419 次
?
以下的文章主要讲述的是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.
?
- altersystemsetglobal_names=truescope=both;
二.在两个数据库上分别创建应用用户CQM
?
- CREATEUSERCQMIDENTIFIEDBYCQMDEFAULTTABLESPACECQMTEMPORARYTABLESPACETEMP;
- GRANTDBATOCQM;
?
三.在两个数据库上分别创建复制管事员用户REPADMIN
创建repadmin用户管理复制环境
?
- 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');
在复制组里加入复制对象:
?
- executedbm