热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Oracle主从同步、双向同步的配置

(本教程展示了Windows环境的oracle数据库主从同步,Linux环境一样也可以)(把主数据库obpm和从数据库orcl用实际的数据库名给替换掉)(配置主从同步后,再配置双向同步,可

(本教程展示了Windows环境的oracle数据库主从同步,Linux环境一样也可以)

(把主数据库obpm 和从数据库orcl 用实际的数据库名给替换掉)

配置主从同步后,再配置双向同步,可能会有表数据重叠,建议在配置双向同完成后,再导入表数据!)

备注:主、从数据库都用淡蓝色标记了,方便查找替换。

1.环境介绍

  主数据库SID : obpm
  操作系统 :    win 2003 
  IP地址   :  192.168.0.1 
  Global_name : 
  oracle version: 10.2.0.1 

  从数据库SID: orcl 
  操作系统 :    win 2003 
  IP地址   :  192.168.0.2 
  Global_name : 
  oracle version: 10.2.0.1 

 

2.在主/从数据库设置初始化参数(在主从数据库都执行以下操作)

以as sysdba身份,可在sqlplus中执行
  1)  以dba身份登录

sqlplus / as sysdba

  2)  设置参数

alter system set aq_tm_processes=2 scope=both;   ---启用对队列消息的时间监视 
alter system set global_names=true scope=both;   ---设置全局名称为true 
alter system set undo_retention=3600 scope=both;   --设置回滚段时间,默认是900 
alter system set streams_pool_size=25M scope=spfile; --sga设置为自动调整情况下不需设置该参数 

  3)重启动两个数据库,重启方式:

1.shutdown immediate
2.startup
3.$lsnrctl start(一般都会提示监听已经启动)
(windows服务中也可手动启动监听)

3.设置主数据库(obpm )为归档mode (以as sysdba身份,可在sqlplus中执行)

  1)  --查是否归档,如是归档,请忽略第3点 

 archive log list;

  2) 归档设置

 shutdown immediate;
 startup mount;
 alter database archivelog;
 alter system set LOG_ARCHIVE_DEST_1='LOCATION=C:\Ora\arc\';  ---设置归档目录 (执行此句后,在Windows系统文件夹中看看arc文件夹有没有创建成功,如果没有,则手动创建,在执行此语句)
 alter database open;
 alter system switch logfile; --相应目录检查是否生成arc文件 (如果提示数据库没开启,则先执行alter database open;)

 

4.主/从数据新建stream管理用户(在主从数据库都执行以下操作) 

 sqlplus / as sysdba;
 create tablespace tbs_stream datafile 'C:\Ora\tbs_stream01.dbf' size 2000m autoextend on maxsize unlimited segment space management auto; ---创建主环境的Stream专用表空间
 execute dbms_logmnr_d.set_tablespace('tbs_stream'); --将logminer的数据字典从system表空间转移到新建的表空间,防止撑满system表空间 
 create user strmadmin identified by strmadmin default tablespace tbs_stream temporary tablespace temp;  --创建用户 
 grant dba to strmadmin;  --直接给dba权限. 
(Drop旧的表空间方法:drop tablespace tbs_stream including contents;) 

5.主数据库网络环境设置 (就是在主数据库中增加一个从数据库的连接服务)

1)主数据库中添加从数据库的配置。(通过oracle图形工具net configuration manager配置,服务名为从数据库名orcl并测试与从数据库是否连通

2)新建连接orcl的dblink 

create public database link orcl connect to strmadmin IDENTIFIED BY strmadmin
using '(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.2)(PORT = 1521))
)
(CONNECT_DATA =
(SID= orcl)
)
)';

测试dblink:select sysdate from dual@orcl;  --测试dblink是否有效 

 

6.从数据库网络环境设置 (就是在从数据库中增加一个主数据库的连接服务)

 1)从数据库中添加主数据库的配置。(通过oracle图形工具net configuration manager配置,服务名为主数据库名obpm,并测试与从数据库是否连通

 

2)新建连接obpm的dblink 

create public database link obpm connect to strmadmin IDENTIFIED BY strmadmin
using '(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.1)(PORT = 1521))
)
(CONNECT_DATA =
(SID = obpm)
)
)';

测试dblink:select sysdate from dual@obpm;  --测试dblink是否有效

 

7.主数据库流队列创建 (可在plsql中的SQL中执行,登录名应为strmadmin

connect strmadmin/strmadmin  --以strmadmin身份,登录主数据库。 
begin
dbms_streams_adm.set_up_queue(queue_table => 'obpm_queue_table',queue_name => 'obpm_queue');
end;
/

 

8.从数据库流队列创建

connect strmadmin/strmadmin  --以strmadmin身份,登录从数据库。
begin
dbms_streams_adm.set_up_queue(queue_table => 'orcl_queue_table',queue_name => 'orcl_queue');
end;
/

  

9.主数据库创建捕获进程 

connect strmadmin/strmadmin
begin
dbms_streams_adm.add_schema_rules(
schema_name => 'strmadmin',
streams_type => 'capture',
streams_name => 'capture_obpm',
queue_name => 'strmadmin.obpm_queue',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
source_database => null,
inclusion_rule => true);
end;
/

  

10.从数据库实例化strmadmin用户 (win在CMD命令界面中执行)(这两个路径须一致)

exp strmadmin/strmadmin@obpm file='C:\Ora\crm.dmp' object_cOnsistent=y rows=y

在从数据库新建strmadmin 

imp strmadmin/strmadmin@orcl file='C:\Ora\crm.dmp' ignore=y commit=y streams_instantiation=y full=y

  

11.主数据库创建传播进程 

connect strmadmin/strmadmin --以strmadmin身份,登录主数据库。 
begin
dbms_streams_adm.add_schema_propagation_rules(
schema_name => 'strmadmin',
streams_name => 'obpm_to_orcl',
source_queue_name => 'strmadmin.obpm_queue',
destination_queue_name => 'strmadmin.orcl_queue@orcl',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
source_database => 'obpm',
inclusion_rule => true);
end;
/

注意:此段语句执行可能会报错,如果报错,不用管,继续执行后面的。

修改propagation休眠时间为0,表示实时传播LCR,latency以秒为单位 

begin
dbms_aqadm.alter_propagation_schedule(
queue_name => 'obpm_queue',
destination => 'orcl',
latency => 0);
end;
/

 

12.从数据创建应用进程 

connect strmadmin/strmadmin
begin
dbms_streams_adm.add_schema_rules(
schema_name => 'strmadmin',
streams_type => 'apply',
streams_name => 'apply_orcl',
queue_name => 'strmadmin.orcl_queue',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
source_database => 'obpm',
inclusion_rule => true);
end;
/

  

13.启动Stream

1)从数据库启动应用进程 

connect strmadmin/strmadmin
begin
dbms_apply_adm.start_apply(
apply_name => 'apply_orcl');
end;
/

2)主数据库启动捕获进程 

connect strmadmin/strmadmin
begin
dbms_capture_adm.start_capture(
capture_name => 'capture_obpm');
end;
/

 

14.现在就可以进行测试了,在crm用户中作何一个测试表新增数据,删除数据,增加表,修改表结构,进行同步测试

 

备注:以上就是主从同步的所有配置,接下来配置双向同步

双向同步前请测试,主从单向同步是否成功!若成功,则下面进行双向同步,若不成功,则拉到下面的“问题检查解决方法处排查问题,主从同步成功后在进行双向同步!!!”

 

双向同步配置:

 

1.设置从数据库(orcl )为归档mode (以as sysdba身份,可在sqlplus中执行)

 

 1)  查是否归档,如是归档,请忽略第3点

archive log list;

 2)  归档设置

shutdown immediate; 
startup mount; 
alter database archivelog; 
alter system set LOG_ARCHIVE_DEST_1='LOCATION=C:\Ora\arc\';  ---设置归档目录 (执行此句后,在Windows系统文件夹中看看arc文件夹有没有创建成功,如果没有,则手动创建,在执行此语句)
alter database open;
alter system switch logfile; --相应目录检查是否生成arc文件 (如果提示数据库没开启,则先执行alter database open;)    

 

2.从数据库(orcl )创建捕获进程

connect strmadmin/strmadmin
begin
dbms_streams_adm.add_schema_rules(
schema_name => 'strmadmin',
streams_type => 'capture',
streams_name => 'capture_orcl',
queue_name => 'strmadmin.orcl_queue',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
source_database => null,
inclusion_rule => true);
end;
/

  

3.主数据库(obpm)实例化strmadmin用户 (win在CMD命令界面中执行)(这两个路径须一致)

exp strmadmin/strmadmin@orcl file='C:\Ora\crm.dmp' object_cOnsistent=y rows=y

在主数据库(obpm)新建strmadmin

imp strmadmin/strmadmin@obpm file='C:\Ora\crm.dmp' ignore=y commit=y streams_instantiation=y full=y

  

4.从数据库(orcl)创建传播进程

connect strmadmin/strmadmin --以strmadmin身份,登录从数据库。
begin
dbms_streams_adm.add_schema_propagation_rules(
schema_name => 'strmadmin',
streams_name => 'orcl_to_obpm',
source_queue_name => 'strmadmin.orcl_queue',
destination_queue_name => 'strmadmin.obpm_queue@obpm',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
source_database => 'orcl',
inclusion_rule => true);
end;
/

修改propagation休眠时间为0,表示实时传播LCR,latency以秒为单位

begin
dbms_aqadm.alter_propagation_schedule(
queue_name => 'orcl_queue',
destination => 'obpm',
destination_queue => 'obpm_queue',
latency => 5);
end;
/

 

5.主数据(obpm)创建应用进程

connect strmadmin/strmadmin
begin
dbms_streams_adm.add_schema_rules(
schema_name => 'strmadmin',
streams_type => 'apply',
streams_name => 'apply_obpm',
queue_name => 'strmadmin.obpm_queue',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
source_database => 'orcl',
inclusion_rule => true);
end;
/

  

6.启动Stream

1)主数据库(obpm)启动应用进程

connect strmadmin/strmadmin
begin
dbms_apply_adm.start_apply(
apply_name => 'apply_obpm');
end;
/

2)从数据库(orcl)启动捕获进程

connect strmadmin/strmadmin
begin
dbms_capture_adm.start_capture(
capture_name => 'capture_orcl');
end;
/

 

以上就是双向同步的配置,双向同步完成后,测试是否成功,若不成功,则用下面的“‘主从同步’问题检查解决方法把主从数据库名称调换检查”

主从同步’问题检查解决方法:

 

15.停止stream

1)主数据库停止Capture进程

connect strmadmin/strmadmin
begin
dbms_capture_adm.stop_capture(
capture_name => 'capture_obpm');
end;
/

2)从数据库停止Apply进程

connect strmadmin/strmadmin
begin
dbms_apply_adm.stop_apply(
apply_name => 'apply_orcl');
end;
/

 

16.清除所有配置信息 

1)按上述方法停止capture,applya进程 
 2)分别在主从数据库执行以下语句

connect strmadmin/strmadmin 
exec DBMS_STREAMS_ADM.remove_streams_configuration();

  

17.如何知道捕捉(Capture)进程是否运行正常?

strmadmin身份,登录主数据库,执行如下语句:

SELECT CAPTURE_NAME,QUEUE_NAME,RULE_SET_NAME,NEGATIVE_RULE_SET_NAME,STATUS FROM DBA_CAPTURE;

  如果STATUS状态是ENABLED,表示Capture进程运行正常
  如果STATUS状态是DISABLED,表示Capture进程处于停止状态,只需重新启动即可
  如果STATUS状态是ABORTED,表示Capture进程非正常停止,查询相应的ERROR_NUMBER、ERROR_MESSAGE列可以得到详细的信息;同时,Oracle会在跟踪文件中记录该信息。

 

18. 如何知道Captured LCR是否有传播?

strmadmin身份,登录主数据库,执行如下语句:

SELECT CAPTURE_NAME, QUEUE_NAME, STATUS, CAPTURED_SCN, APPLIED_SCN FROM DBA_CAPTURE;

  如果APPLIED_SCN小于CAPTURED_SCN,则表示在主数据库一端,要么LCR没有被dequeue,要么Propagation进程尚未传播到从数据库一端。

  如果出现此情况,主库进程重启下,看看 APPLIED_SCN和CAPTURED_SCN是否相等,若相等,再重启下从库进程即可。

 

19.如何知道Appy进程是否运行正常

strmadmin身份,登录从数据库,执行如下语句:

SELECT apply_name, apply_captured, status FROM dba_apply; 

  如果STATUS状态是ENABLED,表示Apply进程运行正常; 
  如果STATUS状态是DISABLED,表示Apply进程处于停止状态,只需重新启动即可; 
  如果STATUS状态是ABORTED,表示Apply进程非正常停止,查询相应的ERROR_NUMBER、ERROR_MESSAGE列可以得到详细的信息; 
  同时,可以查询DBA_APPLY_ERROR视图,了解详细的Apply错误信息。 
  其它错误请跟踪alter.log

 

注意:

第一步:如果在重启操作系统,或者数据库后,出现主从数据库无法同步的情况时,请用17,18,,19步的方法查看;

第二步:在19步查询出现“ABORTED”时,请用SELECT apply_name, apply_captured, ERROR_NUMBER, ERROR_MESSAGE, status FROM dba_apply进行查询;

错误原因:

select error_message,error_creation_time from dba_apply_error order by error_creation_time desc;
select * from dba_apply_error order by error_creation_time desc;

会出现:

(用户没有实例化)

这时候需要重新在从数据库这边系统的cmd中执行实例化用户即可:

exp strmadmin/strmadmin@obpm file='C:\Ora\crm.dmp' object_cOnsistent=y rows=y 

第三步:

从数据库停止Apply进程

connect strmadmin/strmadmin
begin
dbms_apply_adm.stop_apply(
apply_name => 'apply_orcl');
end;
/

从数据库启动应用进程

connect strmadmin/strmadmin
begin
dbms_apply_adm.start_apply(
apply_name => 'apply_orcl');
end;
/

 这样就解决了出现的问题。出现问题的原因是在第10步的实例化用户没成功(查看windows文件夹下有没有创建“crm.dmp”文件,如果没有创建,则说明实例化用户不成功,重启后则会出现此错误)

 

 以上就是Oracle主从同步和双向同步的配置,和常见问题的解决方法,一般来说只要按照上面步骤一步一步走,应该没有问题。

 注意的是sql语句后面粘贴复制经常会出现空格,有空格会报错,这点经常会不小心遇到。遇到问题不用担心,按照上面的方法进行排查即可,如果真的配错了,执行清除命令重新配置即可。

 


推荐阅读
  • Webmin远程命令执行漏洞复现及防护方法
    本文介绍了Webmin远程命令执行漏洞CVE-2019-15107的漏洞详情和复现方法,同时提供了防护方法。漏洞存在于Webmin的找回密码页面中,攻击者无需权限即可注入命令并执行任意系统命令。文章还提供了相关参考链接和搭建靶场的步骤。此外,还指出了参考链接中的数据包不准确的问题,并解释了漏洞触发的条件。最后,给出了防护方法以避免受到该漏洞的攻击。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • 本文讨论了在数据库打开和关闭状态下,重新命名或移动数据文件和日志文件的情况。针对性能和维护原因,需要将数据库文件移动到不同的磁盘上或重新分配到新的磁盘上的情况,以及在操作系统级别移动或重命名数据文件但未在数据库层进行重命名导致报错的情况。通过三个方面进行讨论。 ... [详细]
  • Oracle10g备份导入的方法及注意事项
    本文介绍了使用Oracle10g进行备份导入的方法及相关注意事项,同时还介绍了2019年独角兽企业重金招聘Python工程师的标准。内容包括导出exp命令、删用户、创建数据库、授权等操作,以及导入imp命令的使用。详细介绍了导入时的参数设置,如full、ignore、buffer、commit、feedback等。转载来源于https://my.oschina.net/u/1767754/blog/377593。 ... [详细]
  • 本文讨论了clone的fork与pthread_create创建线程的不同之处。进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合。在调用系统调用fork创建一个进程时,子进程只是完全复制父进程的资源,这样得到的子进程独立于父进程,具有良好的并发性。但是二者之间的通讯需要通过专门的通讯机制,另外通过fork创建子进程系统开销很大。因此,在某些情况下,使用clone或pthread_create创建线程可能更加高效。 ... [详细]
  • Oracle seg,V$TEMPSEG_USAGE与Oracle排序的关系及使用方法
    本文介绍了Oracle seg,V$TEMPSEG_USAGE与Oracle排序之间的关系,V$TEMPSEG_USAGE是V_$SORT_USAGE的同义词,通过查询dba_objects和dba_synonyms视图可以了解到它们的详细信息。同时,还探讨了V$TEMPSEG_USAGE的使用方法。 ... [详细]
  • Windows7 64位系统安装PLSQL Developer的步骤和注意事项
    本文介绍了在Windows7 64位系统上安装PLSQL Developer的步骤和注意事项。首先下载并安装PLSQL Developer,注意不要安装在默认目录下。然后下载Windows 32位的oracle instant client,并解压到指定路径。最后,按照自己的喜好对解压后的文件进行命名和压缩。 ... [详细]
  • Skywalking系列博客1安装单机版 Skywalking的快速安装方法
    本文介绍了如何快速安装单机版的Skywalking,包括下载、环境需求和端口检查等步骤。同时提供了百度盘下载地址和查询端口是否被占用的命令。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 本文介绍了C#中生成随机数的三种方法,并分析了其中存在的问题。首先介绍了使用Random类生成随机数的默认方法,但在高并发情况下可能会出现重复的情况。接着通过循环生成了一系列随机数,进一步突显了这个问题。文章指出,随机数生成在任何编程语言中都是必备的功能,但Random类生成的随机数并不可靠。最后,提出了需要寻找其他可靠的随机数生成方法的建议。 ... [详细]
  • 本文详细介绍了在ASP.NET中获取插入记录的ID的几种方法,包括使用SCOPE_IDENTITY()和IDENT_CURRENT()函数,以及通过ExecuteReader方法执行SQL语句获取ID的步骤。同时,还提供了使用这些方法的示例代码和注意事项。对于需要获取表中最后一个插入操作所产生的ID或马上使用刚插入的新记录ID的开发者来说,本文提供了一些有用的技巧和建议。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 如何在服务器主机上实现文件共享的方法和工具
    本文介绍了在服务器主机上实现文件共享的方法和工具,包括Linux主机和Windows主机的文件传输方式,Web运维和FTP/SFTP客户端运维两种方式,以及使用WinSCP工具将文件上传至Linux云服务器的操作方法。此外,还介绍了在迁移过程中需要安装迁移Agent并输入目的端服务器所在华为云的AK/SK,以及主机迁移服务会收集的源端服务器信息。 ... [详细]
  • ALTERTABLE通过更改、添加、除去列和约束,或者通过启用或禁用约束和触发器来更改表的定义。语法ALTERTABLEtable{[ALTERCOLUMNcolu ... [详细]
author-avatar
妖童J
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有