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. HDU 2828 Lamp 二分图的最大匹配 模型题

    http://acm.hdu.edu.cn/showproblem.php?pid=2828 给定n个灯,m个开关,使得每栈灯亮,前提是控制这栈灯的开关的状态是其中一个.(题目应该都看得懂) 其实我想 ...

  2. Spring-aop(一)

    写一个计算类,计算前后需要打印日志. interface ArithmeticCalculator { public int add(int i, int j); public int sub(int ...

  3. 通过HTML 取得页面、屏幕、浏览器的高度宽度

    一.介绍 1. 容器 一个页面的展示,从外到内的容器为:屏幕.浏览器以及页面本身. HTML元素展现在页面内,页面展现在浏览器内,而浏览器展现在屏幕内. 通过Js的一些对象可以获取这些容器的高度.宽度 ...

  4. Android性能分析工具Profile GPU rendering详细介绍

    如何在一个应用中追踪和定位性能问题,甚至在没有它的源代码的情况下?? “Profile GPU rendering”(GPU渲染分析),一款Android4.1所引入的工具.你可以在“设置”应用的“开 ...

  5. java写跳一跳辅助程序

    ##起初是想使用按键精灵脚本程序控制,但还是选择熟悉的java.我这里使用了工具,造成延迟问题.也求教:java控制安卓的正确姿势, 参考了.NET玩跳一跳,思路都是一样的,只不过使用ADB控制安卓的 ...

  6. Handler引起的内存泄露

    一般我都写handler的时候是这样的:   public class MyActivity extends Activity{ private final Handler myHandler = n ...

  7. java大文件读写操作,java nio 之MappedByteBuffer,高效文件/内存映射

    java处理大文件,一般用BufferedReader,BufferedInputStream这类带缓冲的Io类,不过如果文件超大的话,更快的方式是采用MappedByteBuffer. Mapped ...

  8. C# 图片打印杂谈

    日常开头水一下,看了下上次博客,一年零八天了,啧啧,奢侈. 最近这个工作挺满意的,是我想要的发展方向,后续要做机器学习,现在得先把公司之前堆积的问题解决了. 谈人生到此结束,还是说正题吧.(感觉这标题 ...

  9. 什么是Entitlement

    Entitlement(权限),可以想象成App里用于描述该App可以调用哪些服务的字符串.苹果的操作系统(mac os或者iOS)会通过检查这个串,决定这个应用是否可以调用相关功能.比如iCloud ...

  10. python小随笔

    关于pip安装 .\pip.exe install --ignore-installed --upgrade tensorflow-gpu python可视化库 Seaborn:是一个基于matplo ...