基于Archivelog方式实现ORACLE异地数据库与本地数据库同步的研究_第1页
基于Archivelog方式实现ORACLE异地数据库与本地数据库同步的研究_第2页
基于Archivelog方式实现ORACLE异地数据库与本地数据库同步的研究_第3页
基于Archivelog方式实现ORACLE异地数据库与本地数据库同步的研究_第4页
基于Archivelog方式实现ORACLE异地数据库与本地数据库同步的研究_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、基于归档日志传送方式实现oracle远程数据库与本地数据库同步oracle 9i提供的保持本地数据库和远程数据库的机制,通过archive log的传送,使两个数据库保持在同步,可以实现数据自动异地备份。实现的方式如下图所示:图 1 实现原理示意图初始时,db2和db1内容是相同的,db2以standby方式运行,在db1在形成归档日志的时候,除了存储到本地文件系统以外,还传送一份到远端的standby数据库db2。db2自动应用这份归档日志,对其数据库中的数据进行修改,以达到二者同步的目的。这种功能对于关键应用保持一个备份的数据中心非常有用。下面对这种实现方式进行详细的描述:基础环境如下:主

2、机系统为两台ibm p630小型机,操作系统为aix 5.2,数据库为oracle 。primary db(主数据库)standby db(备用数据库)主机ip主机名称hostahostb服务名称payrollpayrollsidpayroll1payroll2实现步骤如下:1. 主数据库的准备工作(1) 将主数据库置于force logging方式:sql> alter database force logging;(2) 将主数据库置于archivelog模式,并且设置一个本地的归档路径:sql> alter syste

3、m set log_archive_dest_1='location=/disk1/oracle/oradata/payroll mandatory' scope=both;sql> alter system set log_archive_dest_state_1=enable scope=both;sql> alter system set log_archive_start=true scope=spfile;sql>shutdown immediatesql>startup mountsql>alter database archivelo

4、g;sql>alter dattabase open;2. 创建一个备份数据库(1) 从数据字典中找到所有的数据文件sql> select name from v$datafile;name -/disk1/oracle/oradata/payroll/system01.dbf/disk1/oracle/oradata/payroll/undotbs01.dbf/disk1/oracle/oradata/payroll/cwmlite01.dbf.(2) 创建一个主数据库的冷备份,再将主数据库启动:首先,关闭主数据库sql> shutdown immediate;将数据文件拷

5、贝到一个临时的目录cp /disk1/oracle/oradata/payroll/* /disk1/oracle/oradata/standby/再将主数据库启动sql> startup;(3) 创建备用数据库的控制文件在主数据库中,用下列命令为备用数据库创建控制文件于临时目录下:sql> alter database create standby controlfile as '/disk1/oracle/oradata/payroll/standby/payroll2.ctl'(4) 为备用数据库创建参数文件在主数据库中,使用下列语句,为备用数据库创建一个参数

6、文件:create pfile='/disk1/oracle/dbs/initpayroll2.ora' from spfile;(5) 将前三步数据文件、控制文件、参数文件从hosta传输到hostb,可以使用ftp的方法传输。(6) 对备用数据库参数文件($oracle_home/dbs/initpayroll2.ora)进行修改:control_files='/disk1/oracle/oradata/payroll/standby/payroll2.ctl' standby_archive_dest='/disk1/oracle/oradata/

7、payroll/standby' db_file_name_convert=('/disk1/oracle/oradata/payroll/', '/disk1/oracle/oradata/payroll/standby/')log_file_name_convert=('/disk1/oracle/oradata/payroll/', '/disk1/oracle/oradata/payroll/standby/')log_archive_dest_1=('location=/disk1/oracle/orad

8、ata/payroll/standby/')standby_file_management=autoremote_archive_enable=trueinstance_name=payroll2(7) 配置备用数据库的$oracle_home/network/admin/listener.ora文件,并重启监听程序。首先,关闭备用数据库的监听程序:$ lsnrctl stop然后,可以$oracle_home/bin/netca进行图形化的设定,也可以直接修改$oracle_home/network/admin/listener.ora,内容如下:listener = (descri

9、ption_list = (description = (address_list = (address = (protocol = tcp)(host = hostb)(port = 1521) ) (address_list = (address = (protocol = ipc)(key = extproc0) ) ) )sid_list_listener = (sid_list = (sid_desc = (sid_name = plsextproc) (oracle_home = /home/oracle/product/) (program = extproc) )

10、 (sid_desc = (global_dbname = payroll) (oracle_home = /home/oracle/product/) (sid_name = payroll2) ) )再启动备用数据库的监听程序:$ lsnrctl start(8) 在备用数据库的$oracle_home/network/admin/sqlnet.ora中加入死锁检测:sqlnet.expire_time=2(9) 为主数据库配置$oracle_home/network/admin/tnsnames.ora,以连接备用数据库,加入:payroll2 = (description

11、 = (address_list = (address = (protocol = tcp)(host = hostb)(port = 1521) ) (connect_data = (sid = payroll2) ) ) (10) 为备用数据库创建spfile:在备用数据库中运行:sql> create spfile from pfile='initpayroll2.ora'(11) 启动备用数据库,置于备份模式:sql> startup nomount;sql> alter database mount standby database;(12) 启动备

12、用数据库的log apply services服务: 在备用数据库中,运行下面语句:sql> alter database recover managed standby database disconnect from session;(13) 启动主数据库向备用数据库的归档日志传输:在主数据库中,运行下面语句:sql> alter system set log_archive_dest_2='service=payroll2' scope=both; sql> alter system set log_archive_dest_state_2=enable

13、 scope=both;3. 测试是否可以进行归档传输:(1) 查询备用数据库的archive log 情况sql> select sequence#, first_time, next_time from v$archived_log order by sequence#; sequence# first_time next_time- - - 108 27-4月 -05 17:50:46 27-4月 -05 17:50:54 109 27-4月 -05 17:50:54 27-4月 -05 17:50:59 110 27-4月 -05 17:50:59 27-4月 -05 17:51

14、:043 rows selected.(2) 在主数据库中进行手工日志归档:sql> alter system archive log current;检查是否日志传送到备用数据库。(3) 再次查看备用数据库的archive log 情况:sql> select sequence#, first_time, next_time from v$archived_log order by sequence#; sequence# first_time next_time- - - 108 27-4月 -05 17:50:46 27-4月 -05 17:50:54 109 27-4月 -

15、05 17:50:54 27-4月 -05 17:50:59 110 27-4月 -05 17:50:59 27-4月 -05 17:51:04 111 27-4月 -05 17:51:04 27-4月 -05 18:34:124 rows selected.可见,日志已经从主数据库传送到备用数据库了。(4) 验证日志已经被备用数据库进行应用了:从备用数据库中,查询 v$archived_log 视图:sql> select sequence#,applied from v$archived_logorder by sequence#;sequence# app- - 8 yes 9 yes 10 yes 11 yes4 rows selected.4. 备份数据库的激活:在主数据库失效的情况下,可以将备用数据库激活,备用数据库一旦激活成为主数据库,就不能在成为备用数据库,需要重新建立备用数据库。激活备用数据库,首先要停止备用数据库的恢复进程。sql>recover managed standby database cancel;激活备用数据库sql>alter database activate st

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论