Oracle 11g Data Guard 之逻辑备库角色转换

逻辑备库不复制数据库服务,在进行switchover或者failover时,连接主库服务的中间层将不能连接(因为服务的创建没有被复制),或者连接不正确的版本(因为服务属性的修改没有被复制)。

Oracle集群不复制管理逻辑备库的服务,必须手动对主库与备库进行同步,具体的详参Oracle集群管理和部署的相关内容。

一.逻辑备库的switchover操作

当进行switchover操作来改变主库和逻辑备库的角色时,总是在主库启动switchover,然后在逻辑备库完成操作,其中的步骤必须按顺序,否则将不能成功执行switchover。

1.确保主库可以进行switchover操作

通过查询V$DATABASE的SWITCHOVER_STATUS值来确定主库是否可以进行switchover操作:

SQL> SELECT SWITCHOVER_STATUS FROM V$DATABASE;

只要SWITCHOVER_STATUS查询结果是TO STANDBY或者SESSIONS ACTIVE,就表明主库和逻辑备库之间可以进行switchover。否则,查看Data Guard配置是否正确,比如所有的LOG_ARCHIVE_DEST_n参数是否配置正确。

2.当前主库进行切换的准备工作

在当前主库切换为逻辑备库角色之前,先执行如下SQL:

SQL> ALTER DATABASE PREPARE TO SWITCHOVER TO LOGICAL STANDBY;

该语句表明当前主库将很快被切换为逻辑备库角色,并且开始接收新主库传来的redo数据。在主库执行这一步是为了接收被记录在当前逻辑备库redo数据流中的数据字典,见步骤3。

如果该步骤成功执行,那么V$DATABASE.SWITCHOVER_STATUS列的值为PREPARING SWITCHOVER。

3.目标逻辑备库切换准备

通过如下的SQL创建目标逻辑备库的数据字典:

SQL> ALTER DATABASE PREPARE TO SWITCHOVER TO PRIMARY; 

该语句还同时启动了逻辑备库的redo传输服务,该数据库将开始将自身的redo数据发送到当前的主库以及Data Guard配置中的其他备库。接收逻辑备库redo数据的这些数据库但并不应用这些redo数据。

当数据字典开始写入redo数据流中,逻辑备库的V$DATABASE.SWITCHOVER_STATUS值变为PREPARING DICTIONARY,一旦操作成功执行,SWITCHOVER_STATUS变为PREPARING SWITCHOVER。

4.确认当前主库已经为未来的主库redo数据流做好了准备

在完成主库到备库角色的切换之前,通过查询V$DATABASE的SWITCHOVER_STATUS值来确认数据字典已经被主库接收,如果数据字典未被接收,那么切换操作将不能完成。因为当前主库不能够解析新主库传来的redo数据。

SWITCHOVER_STATUS的值表明了switchover的进程,当值为TO LOGICAL STANDBY时,进入步骤5.

SQL> SELECT SWITCHOVER_STATUS FROM V$DATABASE;

备注:终止主库switchover操作:

SQL> ALTER DATABASE PREPARE TO SWITCHOVER CANCEL;

终止逻辑备库switchover操作:

SQL> ALTER DATABASE PREPARE TO SWITCHOVER CANCEL;

5.切换主库到逻辑备库角色

通过如下SQL切换主库到逻辑备库角色:

SQL> ALTER DATABASE COMMIT TO SWITCHOVER TO LOGICAL STANDBY;

该语句将等待当前所有主库停止所有的事务以及防止任何新用户启动新事务,并且建立切换提交的时间点。

该语句还将防止用户对逻辑备库的数据做任何的修改操作,为了确保快速执行完,执行该switchover语句前确保主库在没有更新活动的静止状态,比如,所有用户暂时不要登录主库。可以通过V$TRANSACTION视图查询当前正在进行的事务中可能延迟执行该SQL的详细信息。

此时,主库已经在往备库角色过渡了,你不可以关闭或者重启数据库。

6.确保所有可用的redo数据都已经被应用到将转为新主库的目标逻辑备库中

当完成主库到逻辑备库角色的切换,而且配置中的备库已经接收了切换通知,应确认切换通知已经被目标备库处理,这个可以通过查询目标备库V$DATABASE中的SWITCHOVER_STATUS来核实,一旦所有可用的redo数据已经应用到了逻辑备库,SQL应用会按照预期的角色转换目标而自动关闭。

SWITCHOVER_STATUS值的更新显示switchover的进度,当值为TO PRIMARY,则进入第7步。

SQL> SELECT SWITCHOVER_STATUS FROM V$DATABASE;

7.切换逻辑备库到主库角色

执行如下SQL,完成逻辑备库到主库角色的转换:

SQL> ALTER DATABASE COMMIT TO SWITCHOVER TO PRIMARY;

不需要对Data Guard配置中的逻辑备库进行关闭或者重启的操作,因为配置中的其他逻辑备库将变成新主库的备库,但是任何物理备库还是原主库的备库。

8.新的逻辑备库开启SQL应用

新逻辑备库上执行SQL:

SQL> ALTER DATABASE START LOGICAL STANDBY APPLY IMMEDIATE;

二.逻辑备库的failover操作

本节介绍逻辑备库的failover操作,逻辑备库的failover必须对故障的主库以及所有的逻辑备库进行正确的操作。另外如果主库没有开启闪回功能,那么就只能通过当前主库的备份来重建主库,或者通过主备库切换解决该问题。

根据数据库配置的保护模式和重做传输服务的属性,主库可能会自主恢复所有或部分的修改操作。

1.将主库未发送的重做日志发送到目标备库

如果主库可以装载(mounted),那么有可能可以将主库未发送的重做日志发送到目标备库。如果该操作能成功执行,那么零数据丢失的failover是可能的,即便主库不是运行在零数据丢失的保护模式下。

注意,该操作要确保目标备库的Redo Apply是开启的,并且主库是mount状态。

主库执行如下SQL:

SQL> ALTER SYSTEM FLUSH REDO TO target_db_name;

这里的target_db_name是指接收主库传来的重做日志的备库的DB_UNIQUE_NAME,这个SQL将主库未发送的重做日志刷到目标备库,并且等待重做数据被应用到备库。

2.复制并注册所有的归档重做日志到目标逻辑备库,以使目标逻辑备库成为新的主库。

根据配置的组件条件,你可以访问主库的归档重做日志,那么:

  • 确定逻辑备份数据库是否有任何归档重做日志文件丢失;
  • 从主数据库复制丢失的日志文件到逻辑备份数据库;
  • 注册复制的日志文件。

逻辑备份数据库注册归档的重做日志文件:

SQL> ALTER DATABASE REGISTER LOGICAL LOGFILE -

> '/disk1/oracle/dbs/log-%r_%s_%t.arc';

Database altered.

3.启用LOG_ARCHIVE_DEST_STATE_n

如果之前没有配置基于角色的归档传输路径,配置新主库对应的远程逻辑备库的初始化参数中的远程日志传输路径,手动启用该参数。

比如启用LOG_ARCHIVE_DEST_2:

SQL> ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_2=ENABLE SCOPE=BOTH;

为确保新主库重启后,此次做的更改仍然有效,可以将该参数写进数据库文本初始化参数文件,一般来说,当数据库是主库角色时,必须开启归档到远程目的地,如果是备库角色,该参数就应该disable。

4.激活新主库

在目标备库上执行SQL:

SQL> ALTER DATABASE ACTIVATE LOGICAL STANDBY DATABASE FINISH APPLY;

该语句关闭RFS进程,在目标备库成为新主库之前,应用目标备库中剩下的重做日志,然后停止SQL应用,激活主库。如果没有FINISH APPLY子句,那么在目标备库转为主库角色前,当前目标备库不会应用还未应用的重做日志。

5.Failover后恢复其他备库

确保现有的其他备库继续为新主库提供保护。

6.备份新主库

在执行failover之后,备份新主库,立即执行备份是一个必要的安全措施,因为没有完整的数据库备份,就不能在failover之后对数据库进行恢复。

7.还原失败的主库

Failover之后,原主库可以转换成新主库的逻辑备库,或者可以应用新主库的备份重建为逻辑备库。一旦原主库转换为备库角色,就可以通过swtichover重新转换成主库角色。

本文参阅Oracle官方文档翻译,不足之处欢迎批评指正!

时间: 2024-09-27 22:36:04

Oracle 11g Data Guard 之逻辑备库角色转换的相关文章

Oracle 11g Data Guard 之物理备库角色转换

一.物理备库的Switchover操作 本节主要内容是物理备库的switchover操作,该操作起始于主库,结束于目标备库. 1.确认主库可以切换为standby角色 SQL> SELECT SWITCHOVER_STATUS FROM V$DATABASE; 如果结果显示TO STANDBY或者SESSIONS ACTIVE,则表明主库可以切换为standby角色,否则,切换操作将不可行,因为redo传输不是配置错误就是不能正常进行. 2.主库启动switchover 执行如下SQL语句将主库

Oracle 11g Data Guard 物理备库快速配置指南(上)

缘起 最近做了10g和11g的物理备库配置实验,发现 Data Guard 其实很容易,但是缺少好文档.我是参考官方文档做的实验,觉得它写的不是很清楚的. Google 出来两个pdf文档,读了觉得比官方文档强很多.翻译下,也许会对某些朋友有用.翻译的同时我也好更熟悉下这两个文档.好久没翻译过英文了,可以顺便练练手. 原文档下载地址(墙外): Configure Dataguard 11gR2 Physical Standby Part 1 Configure Dataguard 11gR2 P

Oracle 11g Data Guard 之角色转换

1.1 简介 Data Guard配置包括1个primary角色的数据库和1个或者多个standby角色的数据库,数据库的角色我们可以通过V$DATABASE中DATABASE_ROLE字段来获得. 另外,Data Guard配置中standby库的数量.位置.备库类型以及redo data从主库传到备库的方式,决定了主库发生停机故障时能采用的角色管理方案. 当数据库运行于Data Guard中primary或者standby这样互斥的角色时,可以通过SQL语句或者Data Guard brok

Oracle 11g Data Guard 使用duplicate from active database 创建 standby database

用这种方式来搭建DG ,主库的停机时间很少,只需要重启一下,使参数生效.也可以用这种方法进行DB迁移.DG搭建好,然后把备库激活就可以了. 这样整个迁移中宕机时间也比较短. Oracle 11g的pyhsical standby 支持open read only 下的apply和Real-time query. 因此就有了physical standby 稳定和logical standby 的报表查询功能. Oracle: 11.2.0.1 OS: redhat 5.5 Primary IP:

ORACLE 11G Data Guard 角色转换

1,ORACLE Dataguard角色切换DataGuard已经是现今标准的主流容灾方案,由于日志传递对于网络适应程度强,且可以采用同步实时的传递方式和异步延迟的传递方式,甚至可以成为远程的异地容灾方案.不管用于何种用途,DG都免不了要进行角色转换,即将standby 数据库切换为primary数据库,角色转换分为:switchover和failover两种 2,两种方式的异同1),switchover是primary库转换成standby库.standby库转换成primary库2),fai

利用ORACLE 11g 新特性创建物理备库

准备工作: 主库启用归档 在所有系统上安装oralce 11g软件 备库创建必要的目录 创建监听,配置tnsname文件 第一步: 将主库的密码文件cp一份到备库中 第二步: 主备库的参数文件修改: 主库参数文件如: matrix.__db_cache_size=83886080 matrix.__java_pool_size=4194304 matrix.__large_pool_size=4194304 matrix.__oracle_base='/u2/oracle'#ORACLE_BAS

Data Guard 主备库角色转换

1. switchover操作 1.1 备库先关闭实时日志应用 standby>alter database recover managed standby database cancel; 1.2 主库先判断是否可以支持switchover操作 primary> select switchover_status from v$database; 该值为:TO STANDBY:表示支持.该值为:SESSION ACTIVE:表示主库有激活会话.不妨碍switchover操作. 1.3 启动sw

Oracle 11g Data Guard Broker操作笔记

转载请注明出处:http://blog.csdn.net/guoyjoe/article/details/41548669 一.设置 1.设置broker 在主备库上各设置为trueSQL> alter system set dg_broker_start=true; 2.在主库上操作[[email protected] admin]$ dgmgrl sys/[email protected] DGMGRL> help DGMGRL> help create DGMGRL> CRE

ORACLE 11G 之DATAGUARD搭建逻辑standby

Oracle Data Guard逻辑备库是利用主库的一个备份首先建立一个物理备库,然后再将其转换为逻辑备库.这之后主库将日志传递到备库,备库利用logminer从主库的日志中解析出主库所执行过的SQL,在备库上重新执行一遍,从而保证与主库的数据在逻辑上保持一致.与物理备库相对应的是,物理备库使用的是redo apply,逻辑备库使用的是sql apply.因此逻辑备库仅仅保证数据与主库是在逻辑上是一致的,从而逻辑备库可以处于open状态下并进行相应的DML操作. 在转换physical备库到l