运行Data Guard的条件
1、 在主库和从库的所有机器上必须安装同一个版本的Oracle企业版。
2、 主库必须运行在归档模式下。
3、 主库和从库的操作系统必须一样(允许版本不同),从库可以使用与主库不同的目录结构。
4、 主从库硬件系统的体系结构必须相同。比如:主库运行在64位的Sun Sparc系统上,如果从库是32位的Linux Intel系统就不允许。主从库硬件的配置可以不同,比如:CPU数量、内存大小、存储配置等。
5、 主从库可以是单实例的数据库,也可以是多实例的RAC数据库。
6、 每个主从库必须有它自己的控制文件。
7、 如果把主从库放在了一个系统里,则必须调整初始化参数。
8、 只要使用Data Guard就要保持主库是FORCE LOGGING模式,如果在主库上使用了no logging操作不生成日志,因此数据也不会传递到从库。 9、 管理主从库的用户必须具有SYSDBA权限。 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />
主库:win2003 server ora9i(<?xml:namespace prefix = st1 ns = "urn:schemas-microsoft-com:office:smarttags" />9.2.0.1.0) 192.168.3.135主机名:data580 SID:PRIMARY
从库:win2003 server ora9i(9.2.0.1.0) 192.168.3.136 主机名:data380 SID:STANDBY
1、主库和从库的Oracle 安装的时候都选择相同的安装路径 E:\oracle\ora92 ;并且先不要安装数据库,即在安装过程中“数据库配置”一项下面选择“只安装软件”;
2、在主库上使用DBCA(Database Configuration Assistant)建一个数据库,SID设为PRIMARY;
3、设置主库归档路径为e:\oracle\ora92\database\Archive : Sql>alter system set log_archive_dest_1='LOCATION=e:\oracle\ora92\database\Archive MANDATORY' scope=both;
4、将主库实例、数据库关闭,然后启动实例,但不打开数据库,只启动到数据库挂载模式: Sql>shutdown immediate; Sql>startup mount;
5、将主库设置成归档状态和自动归档模式: Sql>alter database archivelog; Sql>alter system set log_archive_start=true scope=spfile;
6、在主库上面创建从库的控制文件standby.ctl : Sql>alter database create standby controlfile as 'e:\oracle\oradata\standby.ctl';
7、在主库上面创建从库的初始化参数文件standby.ora(将其拷贝回从库后转换成从库的 spfile): Sql>create pfile='e:\oracle\oradata\standby.ora' from spfile;
8、查看主库的数据文件及其的位置: Sql>select name from v$datafile; 记下查询结果中的数据文件的位置。
9、关闭实例: Sql>shutdown immediate;
10、将第6步中的standby.ctl、第7步中的standby.ora和第8步骤中的数据文件、还有E:\oracle\oradata\PRIMARY路径下面的联机日志文件(REDO.LOG)、E:\oracle\ora92\database里面的口令文件PWDPRIMARY.ora备份出来,拷贝到从库中;在从库中创建路径E:\oracle\oradata\PRIMARY ,存放standby.ctl、数据文件、联机日志文件;创建路径E:\oracle\admin\PRIMARY ,在里面创建空文件夹bdump、cdump、udump、create、pfile ;将standby.ora 放到E盘根目录下面;将口令文件PWDPRIMARY.ora更名为PWDSTANDBY.ora ,放到从库的E:\oracle\ora92\database下面。
11、回到主库,启动主库实例和数据库: Sql>startup
12、转回到从库,手动创建服务OracleServiceSTANDBY: oradim -new -sid STANDBY -startmode manual 设置环境变量:在环境变量的“Administrator的用户变量”一栏里面新建一个值,变量名为ORACLE_SID ,变量值为STANDBY(服务名)。
13、创建从库监听器OracleOraHome92TNSListener:进入Net Configuration Assistant ,使用“监听程序配置”来创建从库的监听器,同时会在E:\oracle\ora92\network\admin下面生成listener.ora文件;
14、配置本地NET服务名:进入Net Configuration Assistant ,使用“本地NET服务名配置”来配置,同时会在E:\oracle\ora92\network\admin下面生成tnsnames.ora文件;
15、配置主从库的tnsnames.ora ,都将里面的内容设置成如下内容: STANDBY = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.3.136)(PORT = 1521)) ) (CONNECT_DATA = (SERVICE_NAME = PRIMARY) ) ) PRIMARY = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.3.135)(PORT = 1521)) ) (CONNECT_DATA = (SERVICE_NAME = PRIMARY) ) )
16、修改E根目录下面的初始化参数文件standby.ora ,里面的全部内容如下(删除了原来的control_files参数,将instance_name改成了STANDBY,最后面的7行粗体部分是新添加的内容):
*.aq_tm_processes=1
*.background_dump_dest='e:\oracle\admin\PRIMARY\bdump'
*.compatible='9.2.0.0.0'
*.core_dump_dest='e:\oracle\admin\PRIMARY\cdump'
*.db_block_size=8192
*.db_cache_size=728760320
*.db_domain=''
*.db_file_multiblock_read_count=16
*.db_name='PRIMARY'
*.dispatchers='(PROTOCOL=TCP) (SERVICE=PRIMARYXDB)','(PROTOCOL=TCP)'
*.fast_start_mttr_target=300
*.hash_join_enabled=TRUE
*.instance_name='STANDBY'
*.java_pool_size=20971520
*.job_queue_processes=10
*.large_pool_size=143654912
*.log_archive_dest_1='LOCATION=e:\oracle\ora92\database\Archive MANDATORY'
*.log_archive_start=TRUE
*.open_cursors=300
*.pga_aggregate_target=324009984
*.processes=150
*.query_rewrite_enabled='FALSE'
*.remote_login_passwordfile='EXCLUSIVE'
*.shared_pool_size=242221056
*.sort_area_size=52428800
*.star_transformation_enabled='FALSE'
*.timed_statistics=TRUE
*.undo_management='AUTO'
*.undo_retention=10800
*.undo_tablespace='UNDOTBS1'
*.user_dump_dest='e:\oracle\admin\PRIMARY\udump'
*.standby_file_management=AUTO
*.remote_archive_enable=TRUE
*.lock_name_space='standby'
*.fal_server='primary'
*.fal_client='standby'
*.standby_archive_dest='e:\oracle\ora92\database\Archive'
*.control_files='e:\oracle\oradata\primary\STANDBY.CTL'
17、进入sqlplus将standby.ora创建成从库的spfile : Sql>create spfile from pfile='e:\standby.ora';
18、启动从库的实例,并且将从库设置成standby模式: Sql>startup nomount; Sql>alter database mount standby database;
19、在从库启动日志应用服务: Sql>alter database recover managed standby database disconnect from session;
20、转到主库,启动到物理从库的归档: Sql>ALTER SYSTEM SET LOG_ARCHIVE_DEST_2='SERVICE=PRIMARY' SCOPE=BOTH; Sql>ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_2=ENABLE SCOPE=BOTH;
21、校验Data Guard的运转:
主库,归档当前日志: SQL> ALTER SYSTEM ARCHIVE LOG CURRENT;
从库,校验归档日志是否正常接收: SQL> SELECT SEQUENCE#, FIRST_TIME, NEXT_TIME FROM V$ARCHIVED_LOG ORDER BY SEQUENCE#;
从库,查看新的归档日志是否正常用于恢复:
SQL> SELECT SEQUENCE#,APPLIED FROM V$ARCHIVED_LOG ORDER BY SEQUENCE#;
SEQUENCE# APP --------- ---
8 YES
9 YES
10 YES
11 YES
如果都是像以上那样的内容,都是YES的话,那就成功了。也可以分别查看主从库的E:\oracle\ora92\database\archive文件夹里面的内容,如果从库的和主库的内容一致,就算data guard配置成功了。
22、这个时候从库只是将日志文件拿过来存放起来,但并没有执行日志文件,所以在主库上所做的操作无法在从库上得到结果,即无法在从库上查询数据。要在从库上查询数据,要执行以下语句:在从库上用sysdba 用户连接  Sql>alter database recover managed standby database disconnect from session ; Sql>alter database recover managed standby database cancel ; Sql>alter database open read only ; 查询数据即可。查询完成以后,需要恢复从库为恢复模式  Sql>alter database recover managed standby database disconnect from session ; 这个功能的可以用来查询前一天(或者前若干时间)以前的数据,比如报表之类的,因为今天只能查询昨天以前的报表,对数据的同步性的要求不是那么严格。查询完后一定要将从库设回恢复模式。 

转载于:https://blog.51cto.com/jxwpx/205251

oracle dataguard相关推荐

  1. oracle dataguard详解,Oracle DataGuard数据备份方案详解

    Oracle DataGuard是一种数据库级别的HA方案,最主要功能是冗灾.数据保护.故障恢复等. 在生产数据库的"事务一致性"时,使用生产库的物理全备份(或物理COPY)创建备 ...

  2. oracle dataguard延迟,Oracle DataGuard延迟应用归档归档日志

    1. 查看主库的参数设置: SQL> show parameter log_archive_dest_2 NAME TYPE VALUE ---------------------------- ...

  3. Oracle Dataguard之Real-Time Apply

    Oracle Dataguard一共支持三种模式:最大可用模式(Maximum Availability),最大性能模式(Maximum Performance),最大保护模式(Maximum Pro ...

  4. oracle不一致性关闭下次,Oracle DataGuard

    ```1.文档介绍 本实施方案主要对Oracle DataGuard实施部署作相应的说明.以便实施人员能根据当前业务特点,规划.建设符合高可用.高可靠的数据库集群系统.具体由Oracle DG环境拓扑 ...

  5. Golden Gate 与 Oracle DataGuard的区别

    Golden Gate 与 Oracle DataGuard的区别 项           目 GoldenGate TDM Oracle DataGuard(物理) Oracle DataGuard ...

  6. oracle 共享硬盘主从,oracle dataguard主从切换

    前言: 众所周知DataGuard一般的切换分成两种,一种是系统正常的情况下的切换这种方式为:switchover是无损切换,不会丢失数据:另外一种方式属于灾难情况下的切换,这种情况下一般主库已经启动 ...

  7. Oracle dataguard 正常切换和应急切换

    Oracle dataguard 正常切换和应急切换 oracle dataguard提供异地容灾方案,能有效的防止单点故障和提供高可用技术,这里介绍dataguard正常主备切换和应急切换(应急切换 ...

  8. Oracle dataguard一主两备环境搭建

    Oracle dataguard一主两备环境搭建 测试环境说明: 主 库:Reahat 6.5 x64 + Oracle 11.2.0.3 x64 单机(IP:192.168.6.10  db)  D ...

  9. ORACLE Dataguard安装

    ORACLE Dataguard安装 花了一周时间,终于部署和稳定都整理好了. 拷贝到blog里, 留份记录. 也算是对大家的贡献吧. 当然这篇技术文档很大一部分归功于这位仁兄:  http://bl ...

  10. oracle logical standby,Oracle Dataguard管理命令(logical standby)

    Oracle Dataguard管理命令(logical standby) ################# ##  管理命令: ################# 1.注册日志的命令standby ...

最新文章

  1. php一个数组赋值给对象,php数组与对象相互转换方法
  2. SQL Server的WAITFOR DELAY注入
  3. scanner怎样回到文件开头_Radare2逆向分析dex/so/二进制等文件的使用方法
  4. 微信支付分申请接入流程
  5. UVA - 1604Cubic Eight-Puzzle立体八数码
  6. 第3课 天安门广场 《小学生C++趣味编程》--C++、Scratch
  7. Chrome 内存和CPU消耗量双料冠军
  8. 作为一个程序员需要学多少技能?
  9. Atitit 拦截数据库异常的处理最佳实践
  10. 山西台达plc可编程控制器_可编程控制器16(PLC)数据移位指令
  11. sql 取最近一周的周几_我最近的几周摘要
  12. 1088: 手机短号 (多实例)
  13. 生成固定的句子,句子中含有给定的多个关键词,python代码实现
  14. [渝粤教育] 九江学院 药理学 参考 资料
  15. Java开发中常见的危险信号
  16. 导出富文本格式word
  17. php 无限极分类(两种方式)
  18. python枚举窗口句柄_如何使用 WIN32 API 枚举窗口?
  19. 开源PLM软件Aras详解八 Aras之RelationshipTypes关系类详解
  20. php artisan实现机制,源码解读:php artisan serve

热门文章

  1. linux 文件编码问题
  2. 这三类问题是工控系统最大的威胁
  3. 【图】2015年Google搜索引擎排名算法(完整版)
  4. 三: cocos2d-x代码分析
  5. Vmware Vcenter 5.1 部署安装过程 part 4 vmware vcenter 安装步骤
  6. Chisel3 - Tutorial - VendingMachine
  7. binlog_group_commit_sync_delay 参数对并发的影响
  8. 才做三个月的新业务,为何唐岩对陌陌直播寄予厚望
  9. python,day13-堡垒机
  10. 第九章 硬件抽象层:HAL 心得笔记