热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

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

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

  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高级复制之同步复制的介绍,望你能有所收获。

推荐阅读
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 探讨如何通过编程技术实现100个并发连接,解决线程创建顺序问题,并提供高效的并发测试方案。 ... [详细]
  • 梦幻西游挖图奇遇:70级项链意外触发晶清诀,3000W轻松到手
    在梦幻西游中,挖图是一项备受欢迎的活动,无论是小宝图还是高级藏宝图,都吸引了大量玩家参与。通常情况下,小宝图的数量保证了稳定的收益,但特技装备的出现往往能带来意想不到的惊喜。本文讲述了一位玩家通过挖图获得70级晶清项链的故事,最终实现了3000W的游戏币逆袭。 ... [详细]
  • 本文探讨了 RESTful API 和传统接口之间的关键差异,解释了为什么 RESTful API 在设计和实现上具有独特的优势。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 如何配置Unturned服务器及其消息设置
    本文详细介绍了Unturned服务器的配置方法和消息设置技巧,帮助用户了解并优化服务器管理。同时,提供了关于云服务资源操作记录、远程登录设置以及文件传输的相关补充信息。 ... [详细]
  • 网络攻防实战:从HTTP到HTTPS的演变
    本文通过一系列日记记录了从发现漏洞到逐步加强安全措施的过程,探讨了如何应对网络攻击并最终实现全面的安全防护。 ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 邮件(带附件,模拟文件上传,跨服务器)发送核心代码1.测试邮件发送附件接口***测试邮件发送附件*@parammultipartFile*@return*@RequestMappi ... [详细]
  • 360SRC安全应急响应:从漏洞提交到修复的全过程
    本文详细介绍了360SRC平台处理一起关键安全事件的过程,涵盖从漏洞提交、验证、排查到最终修复的各个环节。通过这一案例,展示了360在安全应急响应方面的专业能力和严谨态度。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 本文探讨了在不使用服务器控件的情况下,如何通过多种方法获取并修改页面中的HTML元素值。除了常见的AJAX方式,还介绍了其他可行的技术方案。 ... [详细]
  • 解读MySQL查询执行计划的详细指南
    本文旨在帮助开发者和数据库管理员深入了解如何解读MySQL查询执行计划。通过详细的解析,您将掌握优化查询性能的关键技巧,了解各种访问类型和额外信息的含义。 ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
author-avatar
周郎某某某
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有