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. 142 Linked List Cycle II 环形链表 II

    给一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null.说明:不应修改给定的链表.补充:你是否可以不用额外空间解决此题?详见:https://leetcode.com/proble ...

  2. IIS6配置FastCGI遇到ERROR5的解决方法

    FastCGI Error The FastCGI Handler was unable to process the request. ------------------------------- ...

  3. vscode中将本地数据push至git repository

    1.新建repository 2.本地写好的代码 3.执行git init 初始化git配置文件 4.提交已暂存文件 5.填写提交信息 6.执行push命令 7.完成

  4. 让jquery.tmpl支持序号${index}

    参考 http://blog.csdn.net/wangji5850/article/details/50913121 压缩的查找第一个map,添加 jQuery.map( h, function( ...

  5. 使用预定义的action值启动系统应用

    1.启动浏览器 Intent intent = new Intent(); intent.setAction(Intent.ACTION_WEB_SEARCH); //可以传一个搜索关键字,会直接显示 ...

  6. leetcode410 Split Array Largest Sum

    思路: dp. 实现: class Solution { public: int splitArray(vector<int>& nums, int m) { int n = nu ...

  7. web前端工程师入门须知

    本文是写给那些想要入门web前端工程的初学者,高手请路过,也欢迎高手们拍砖. 先说下web前端工程师的价值,目前web产品交互越来越复杂,用户使用体验和网站前端性能优化这些都得靠web前端工程师去做w ...

  8. configure: error: The LBL Packet Capture Library, libpcap, was not found!

    configure: error:  The LBL Packet Capture Library, libpcap, was not found! yum install libpcap*

  9. How `new’ operator works ?

    这是2013年写的一篇旧文,放在gegahost.net上面 http://raison.gegahost.net/?p=15 February 15, 2013 How `new’ operator ...

  10. 1-1 编程基础 GCC程序编译

    GCC简介      Linux系统下的gcc是GNU推出的强大.性能优越的多平台编译器,是GNU的代表作之一.gcc可以在多种硬体平台上编译出可执行程序,其执行效率与一般的编译器相比平局效率要高20 ...