您的位置:首页 > 数据库 > Oracle

oracle数据库高可用DG之gap问题处理

2018-03-05 17:17 489 查看
当备库不能接受到一个或多个主库的归档日志文件时候,就发生了archive gap。丢失的归档日志文件就是gap,如果有gap,如果发生gap,dg会自动检测和处理通过拷贝丢失的日志到备库。gap什么时候被发现当主库在本地归档一个日志,但是备库没有收到,每分钟,主库就会看下他的备库是否在规定日志文件序号上有gap。gap怎么被解决gap 恢复通过投票机制处理,对物理和逻辑备库,dg检查gap及通过在主库上面获取丢失的redo日志文件来解决。自动gap恢复依赖主库的可用性,如果主库不可样,你配置了多个物理备库,那么你可以配置额外的参数,这样redo apply就可以在别的备库上来解决gap。使用fetch archive log(fal)来解决归档gapfal 客户端自动要求归档日志文件的传输。fal服务端处理客户端发过来的请求。fal机制处理下面类型的gap和问题:1当创建了一个物理或逻辑的备库,fal机制自动的获取在主库热备时候产生的归档日志文件2当备库已经接受了归档日志文件,但是出问题了,fal机制能自动重新获取归档日志文件来解决下面问题:1当归档日志文件在被应用到备库之前被删除了2因为磁盘损坏导致的归档日志文件不能被应用3当归档日志文件被别的文件替换了当你有多个物理备库的时候,fal机制能自动获取丢失的归档日志文件在别的物理备库上面。手工检测和解决archive gap在物理备库上,为了检测是否有gap,执行下面的语句SQL> SELECT * FROM V$ARCHIVE_GAP;
    THREAD#  LOW_SEQUENCE#  HIGH_SEQUENCE#
-----------  -------------  --------------
 
4000
         1              7              10上面的例子说明你的物理备库当前缺少线程1的序号7到10文件。然后在主库上定位这些丢失的文件SELECT NAME FROM V$ARCHIVED_LOG WHERE THREAD#=1 AND DEST_ID=1 AND   2> SEQUENCE# BETWEEN 7 AND 10;
拷贝这些日志文件到物理备库,然后注册到物理备库上 ALTER DATABASE REGISTER LOGFILE '/physical_standby1/thread1_dest/arcr_1_7.arc';
注册完这些日之后,可以重新启动redo apply
逻辑备库SQL> COLUMN FILE_NAME FORMAT a55
SQL> SELECT THREAD#, SEQUENCE#, FILE_NAME FROM DBA_LOGSTDBY_LOG L
  2> WHERE NEXT_CHANGE# NOT IN
  3> (SELECT FIRST_CHANGE# FROM DBA_LOGSTDBY_LOG WHERE L.THREAD# = THREAD#)
  4> ORDER BY THREAD#,SEQUENCE#;

   THREAD#  SEQUENCE# FILE_NAME
---------- ---------- -----------------------------------------------
         1          6 /disk1/oracle/dbs/log-1292880008_6.arc
         1         10 /disk1/oracle/dbs/log-1292880008_10.arc
这个例子中说明有gap,因为在逻辑备库上对线程1有2个文件显示,如果是没有gap的话,这个查询会对每个线程显示一个文件,这个结果输出显示注册的最高的文件时序列号10,但是缺少了序列号6的文件拷贝丢失的日志文件,然后注册SQL> ALTER DATABASE REGISTER LOGICAL LOGFILE '/disk1/oracle/dbs/log-1292880008_10.arc';
注册后重启sql apply
原文地址:http://blog.csdn.net/aoerqileng/article/details/39323359
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: