DG1是主库,DG2是备库;运行在最大可用模式。

实验一:未使用using current logfile参数时,备库在最大可用模式下,不能实时同步备库的更新

-此时需要等待主库进行归档---侧面证明备库应用的归档来恢复数据。

BYS@dg1>show parameter log_archive_dest_2
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
log_archive_dest_2                   string      SERVICE=dg2 LGWR SYNC AFFIRM V
                                                 ALID_FOR=(ONLINE_LOGFILES,PRIM
                                                 ARY_ROLE) DB_UNIQUE_NAME=dg2
主库上的log_archive_dest_2 参数中LGWR SYNC AFFIRM意思是用LGWR传输日志,SYNC是同步传输,ARRIFRM是需要确认。
日志的传输方法有以下 :
使用ARCH–把完整的REDO文件COPY到standby数据库服务器上。
使用LGWR,有两种模式:
ASYNC - 异步:redo written by LGWR to local disk---LGWR将redo写到本地LOG文件。LNSn进程读取redo,传到standby服务器上。
SYNC - 同步:Redo written to standby by LGWR -  LGWR讲Redo信息直接写到standby数据库服务器上
[oracle@dg2 ~]$ sqlplus /  as sysdba                 
BYS@dg2>select protection_mode,database_role,protection_level from v$database;
PROTECTION_MODE      DATABASE_ROLE    PROTECTION_LEVEL
-------------------- ---------------- --------------------
MAXIMUM AVAILABILITY PHYSICAL STANDBY MAXIMUM AVAILABILITY
SYS@dg2>alter database recover managed standby database disconnect from session;
Database altered.

1.此时在dg1-主库上进行插入数据操作

BYS@dg1>select * from test;
         A
----------
       999
       123
       333
       111
BYS@dg1>insert into test values(555);
1 row created.
BYS@dg1>commit;
Commit complete.

2.返回dg2备库上进行查询操作--验证数据同步情况

我这里未使用ACTIVE STANDBY,如果使用更方便,只需要停止应用并查询就可以了。

SYS@dg2>alter database recover managed standby database cancel;
Database altered.
SYS@dg2>alter database open;
Database altered.
SYS@dg2>select open_mode from v$database;
OPEN_MODE
--------------------
READ ONLY
SYS@dg2>conn bys/bys
Connected.
不能查询到DG1上的最新数据。
BYS@dg2>select * from test;
         A
----------
       999
       123
       333
       111
BYS@dg2>conn / as sysdba
SYS@dg2>shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SYS@dg2>startup mount;

3.此时切换主库REDO日志,产生的日志大致如下:--日志是后来补上的,日期不 一样,环境 相同

[oracle@dg1 ~]$ cat alert_dg.log
Thu Aug 08 10:07:43 2013
LGWR: Standby redo logfile selected to archive thread 1 sequence 44
LGWR: Standby redo logfile selected for thread 1 sequence 44 for destination LOG_ARCHIVE_DEST_2
Thread 1 advanced to log sequence 44 (LGWR switch)
  Current log# 2 seq# 44 mem# 0: /u01/oradata/dg/redo02.log
Thu Aug 08 10:07:43 2013
Archived Log entry 65 added for thread 1 sequence 43 ID 0x676c9833 dest 1:   -------43号归档已经完成

[oracle@dg2 ~]$ cat alert_dg.log
Thu Aug 08 10:07:42 2013
Standby controlfile consistent with primary
RFS[1]: Selected log 4 for thread 1 sequence 44 dbid 1735160627 branch 821829622
Thu Aug 08 10:07:42 2013
Archived Log entry 29 added for thread 1 sequence 43 ID 0x676c9833 dest 1:   -------43号归档已经完成
Thu Aug 08 10:07:46 2013
Media Recovery Log /u01/archivelog/arc_1_43_821829622.arc
Media Recovery Waiting for thread 1 sequence 44 (in transit)

实验二:使用using current logfile参数,可以实时同步主库的更新。

SYS@dg2>alter database
recover managed standby database using current logfile disconnect from session;
Database altered.

1.此时在主库上进行DML操作:

BYS@dg1>
BYS@dg1>set time on
17:31:36 BYS@dg1>insert into test values(666);
1 row created.
17:31:49 BYS@dg1>
17:31:54 BYS@dg1>commit;
Commit complete.
17:31:58 BYS@dg1>

2.在备库上以read-only模式打开数据库并进行查看--要在主库的操作提交后再到备库上操作:

SYS@dg2>set time on
17:31:39 SYS@dg2>
17:32:11 SYS@dg2>alter database recover managed standby database cancel;
Database altered.
17:32:40 SYS@dg2>alter database open;
Database altered.
17:32:54 SYS@dg2>conn bys/bys
Connected.
查询结果显示,备库上已经同步到了主库的最新操作。
17:32:59 BYS@dg2>select * from test;
         A
----------
       999
       123
       333
       555
       666
       111
17:33:03 BYS@dg2>

3.此时的日志大致如下,也有日志切换(alter system switch lofile)

11:15:39 SYS@dg1>alter system switch logfile;
System altered.
11:15:48 SYS@dg1>exit

[oracle@dg1 ~]$ cat alert_dg.log
Thu Aug 08 11:15:48 2013
LGWR: Standby redo logfile selected to archive thread 1 sequence 55
LGWR: Standby redo logfile selected for thread 1 sequence 55 for destination LOG_ARCHIVE_DEST_2
Thread 1 advanced to log sequence 55 (LGWR switch)
  Current log# 1 seq# 55 mem# 0: /u01/oradata/dg/redo01.log
Thu Aug 08 11:15:48 2013
Archived Log entry 87 added for thread 1 sequence 54 ID 0x676c9833 dest 1:   54号归档已经完成

[oracle@dg2 ~]$ cat alert_dg.log
Thu Aug 08 11:15:48 2013
Archived Log entry 40 added for thread 1 sequence 54 ID 0x676c9833 dest 1:   54号归档已经完成
Thu Aug 08 11:15:48 2013
Standby controlfile consistent with primary
Thu Aug 08 11:15:48 2013
Media Recovery Waiting for thread 1 sequence 55 (in transit)
RFS[12]: Selected log 4 for thread 1 sequence 55 dbid 1735160627 branch 821829622
Recovery of Online Redo Log: Thread 1 Group 4 Seq 55 Reading mem 0
  Mem# 0: /u01/oradata/dg/standbyredo04.log
Thu Aug 08 11:15:49 2013
RFS[13]: Assigned to RFS process 3881
RFS[13]: Identified database type as 'physical standby': Client is ARCH pid 2929

http://blog.csdn.net/haibusuanyun/article/details/11524053

使用using current logfile实现DG备库实时更新的更多相关文章

  1. 模拟主库创建数据文件,dg备库空间不足时问题处理

    本篇文档测试目的: 模拟实际环境中,主库对表空间添加数据文件,备库空间不足,最终导致MRP进程自动断开,处理方式. 1.问题环境模拟 1)正常情况下的dg 主库创建数据文件,备库接受日志,自动创建表空 ...

  2. DG备库,实时应用如何判断,MR进程,及MRP应用归档,三种情况的查询及验证

    本篇文档学习,DG备库,实时应用如何判断,MR进程,及MRP应用归档,三种情况的查询及验证 1.取消MRP进程 备库查询进程状态select process,client_process,sequen ...

  3. DG备库无法接受主库归档日志之密码文件

    DG备库无法接受主库归档日志之密码文件 实验目的:还原某个客户案例,客户审计需要,对主库sys用户进行锁定,一小时后对sys用户进行解锁后,发现备库无法接受主库的归档日志 本篇文章,测试sys用户与D ...

  4. Oracle-DG最大保护模式下,dg备库出现问题对主库有什么影响?

    一.需求 疑问?Oracle最大保护模式下,dg备库出现问题,影响主库吗? 我们都知道Oracle最大保护模式的意思是oracle不允许数据丢失,1条记录都不行! 那么备库有问题? oracle主库还 ...

  5. DG备库缺失归档文件GAP日志

    问题现象: XXXsdgebus-dg GAP手工注册归档 #出现GAP idle>select * from v$archive_gap; THREAD# LOW_SEQUENCE# HIGH ...

  6. oracle dg 备库不同步主库数据

    今天遇到一个数据库同步问题,主库被关闭,重启主库后,备库不能正常同步主库数据.只有当手动切换归档日志的时候,备库才能和主库一致. 这个问题的解决方法: 重启备库,重新应用归档日志. 操作步骤如下: / ...

  7. DG备库磁盘空间满导致无法创建归档

    上周五去某客户那里做数据库巡检.是window 2008系统上10g的一套NC系统的库,已经配置了DG,可是巡检时发现数据库报错: Tue Nov 11 10:13:57 2014 LNS: Stan ...

  8. 使用DUPLICATE 方式创建ORACLE 11G DG备库环境

    我的最佳实践 ① 手动创建好初始化参数文件: *.audit_file_dest='E:\APP\XJXU\ADMIN\ORASTAND\ADUMP'*.control_files='E:\APP\X ...

  9. Oracle DG备库强制switch_over过程

    故障描述: 主库异常下线,需要将备库强制启动为主库,切断日志时提示需要介质恢复,执行介质恢复后,再激活日志即可进行切换 1.  执行alter database recover managed sta ...

随机推荐

  1. Vijos p1518河流 树形DP

    https://vijos.org/p/1518 这题代码我基本是抄的,实在太难想了.但是也学到了一些东西. 比如:多叉树转二叉树存,这个细细一想,确实使得在dfs的时候,实现起来方便很多. 说一说具 ...

  2. v-bind和v-on

    v-bind指令用于设置HTML属性:v-bind:href  缩写为 :href <a :href="{{url}}">aa</a> v-on 指令用于绑 ...

  3. 使用NPOI操作Excel文件及其日期处理

    工作中经常遇到需要读取或导出Excel文件的情况,而NPOI是目前最宜用.效率最高的操作的Office(不只是Excel哟)文件的组件,使用方便,不详细说明了. Excel工作表约定:整个Excel表 ...

  4. 多路复用IO和异步IO

    多路复用I/O 它的基本原理就是select/epoll这个function会不断的轮询所负责的所有socket,当某个socket有数据到达了,就通知用户进程. 流程图如下: 当用户进程调用了sel ...

  5. 序列化json模块

    1.用json模块来进行序列化和反序列化 注意:用json序列化的数据类型得到的文件后缀名必须是json.因为如果不是json后缀,别人也不知道这是用json序列化的文件. 序列化:json.dump ...

  6. 初学者可能不知道的vue技巧

    前言 大家好,这里是@IT·平头哥联盟,我是首席甩锅官——老金,今天给大家分享的,一些日常中神秘而又简单的vue的实用小技巧,以及我在我司项目中实用vue的总结和坑,跟大家一起分享,希望能给其他攻城狮 ...

  7. jstat查看JVM的GC情况

    jps(Java Virtual Machine Process Status Tool)是JDK 1.5提供的一个显示当前所有java进程pid的命令,简单实用,非常适合在linux/unix平台上 ...

  8. SAP CRM点了附件的超链接后报错的处理方式

    SAP CRM系统里,点击了附件的这些超链接后,如果是文本文件,会在浏览器里打开.如果是其他类型的文件,会弹出下载对话框. 然而最近我工作时遇到一个问题,点击超链接后,总是弹出Logon failed ...

  9. PHP一句话后门过狗姿势万千之后门构造与隐藏

    第二章节主要带给大家一些后门构造思路,与安全狗文件特征检测的机制. 另外强调一下,这篇文章需要大家对于php有一定的认识. 本章节分为三大部分,第一部分针对初级,分析菜刀php代码的执行过程,较基础: ...

  10. Android(java)学习笔记175:Android进程间通讯(IPC)之AIDL

    一.IPC inter process communication  进程间通讯 二.AIDL android  interface  defination  language  安卓接口定义语言 满 ...