DG架构图如下:

计划,切换之后的架构图:

DG切换:

主备切换:
这里所有的数据库数据文件、日志文件的路径是一致的

【旧主库】主库primarydb切换为备库standby3
主库检查switchover_status列的状态,是否支持switchover操作:如果该列值为"TO STANDBY"则表示primary 数据库支持转换为standby 角色
prod> select switchover_status from v$database;
SWITCHOVER_STATUS
--------------------
TO STANDBY
SQL> alter database commit to switchover to physical standby ;
SQL> select instance_name,status from v$instance;
SQL> shutdown immediate

【新建备库】新建备库standby3切换为主库

检查v$database视图的switchover_status列的状态,是否支持switchover操作:
SQL> select switchover_status from v$database;
SWITCHOVER_STATUS
--------------------
TO PRIMARY

SQL> alter database commit to switchover to primary ; --------此时此库可以处于mount模式或open read only模式
SQL> alter database open; -----至此该库转换成为Primary库
SQL> alter system switch logfile; 切日志
SQL> select max(sequence#) from v$archived_log;

新主库spfile修改:

alter system set LOG_ARCHIVE_CONFIG='DG_CONFIG=(primarydb,standby1,standby2,standby3,cascade)'

alter system set log_archive_dest_1 = 'location=/data/app/oracle/arch valid_for=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=primarydb';
alter system set log_archive_dest_2 = 'SERVICE=standby1 SYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=standby1';
alter system set log_archive_dest_3 = 'SERVICE=standby2 SYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=standby2';
alter system set log_archive_dest_4 = 'SERVICE=standby3 SYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=standby3';
alter system set log_archive_dest_5 = 'SERVICE=cascade SYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=cascade';

alter system set FAL_CLIENT='primarydb';
alter system set FAL_SERVER='standby1','standby2','standby3','cascade';

在主备库创建静态listener和tnsnames.ora,远程连接测试

将新主库密码文件拷贝到各个新备库,并改名为orapwinstance_name
备库1:
修改密码文件cd $ORACLE_HOME/dbs mv orapwprimarydb orapwstandby1

alter system set FAL_SERVER=primarydb;

alter system set LOG_ARCHIVE_CONFIG='DG_CONFIG=(primarydb,standby1)'
alter system set log_archive_dest_2 = 'SERVICE=primarydb SYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=primarydb';

备库2:
修改密码文件cd $ORACLE_HOME/dbs mv orapwprimarydb orapwstandby2

alter system set FAL_SERVER=primarydb;

alter system set LOG_ARCHIVE_CONFIG='DG_CONFIG=(primarydb,standby2)'
alter system set log_archive_dest_2 = 'SERVICE=primarydb SYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=primarydb';

备库3:
备库3为先前主库:修改密码文件cd $ORACLE_HOME/dbs mv orapwprimarydb orapwstandby3
启动数据库到mount
SQL>startup mount
开启备库为应用日志模式状态
alter database recover managed standby database using current logfile disconnect from session;

alter system set FAL_SERVER=primarydb;

alter system set LOG_ARCHIVE_CONFIG='DG_CONFIG=(primarydb,standby3)'

alter system set log_archive_dest_2 = 'SERVICE=primarydb SYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=primarydb';
#指向级联备库的参数LOG_ARCHIVE_DEST_3='SERVICE=cascade SYNC VALID_FOR=(STANDBY_LOGFILES,STANDBY_ROLE) DB_UNIQUE_NAME=cascade’;
#因为之前的DG架构为一主三备库,所以应将不需要的归档日志路径log_archive_dest_state_3设置为defer
alter system set log_archive_dest_state_3=defer;

备库4:cascade
修改密码文件cd $ORACLE_HOME/dbs mv orapwprimarydb orapwcascade

alter system set FAL_SERVER=primarydb;

alter system set LOG_ARCHIVE_CONFIG='DG_CONFIG=(primarydb,cascade)'
alter system set log_archive_dest_2 = 'SERVICE=primarydb SYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=primarydb';

采坑:
一:主备库日志缺口:
FAL[client]: Failed to request gap sequence
GAP - thread 1 sequence 10894-10894
DBID 1016818008 branch 918555866
FAL[client]: All defined FAL servers have been attempted.
------------------------------------------------------------
Check that the CONTROL_FILE_RECORD_KEEP_TIME initialization
parameter is defined to a value that's sufficiently large
enough to maintain adequate log switch information to resolve
archivelog gaps.
------------------------------------------------------------

这里的解决方式是:
在主库拷贝相应的日志到备库,然后在备库注册:
alter database register logfile '/data/app/oracle/arch/1_3120_948067048.dbf';

二:主库可以远程连接备库,但是主库报错ORA16191

Error 1017 received logging on to the standby
------------------------------------------------------------
Check that the primary and standby are using a password file
and remote_login_passwordfile is set to SHARED or EXCLUSIVE,
and that the SYS password is same in the password files.
returning error ORA-16191
------------------------------------------------------------

密码文件需要在主库生成,然后拷贝之备库,然后在备库重命名。注意orapw文件的权限。

三:主库不能往新建的备库传日志

log_archive_dest_state_3默认是enable,但是也需要重新配置一下
alter system set log_archive_dest_state_3=enable;

ORACLE Physical Standby DG 之switch over的更多相关文章

  1. ORACLE Physical Standby DG 之fail over

    SQL> select thread#, low_sequence#, high_sequence# from v$archive_gap;确认下是否存在日志间隙,发现gap现象,说明failo ...

  2. ORACLE Physical Standby DG搭建

    主库: 一:强制force logging: alter database force logging; 二:开启主库的归档模式 三:主库添加standby redo log,比redo日志组多一组: ...

  3. ORACLE Physical Standby 级联备库搭建

    搭建oracle 级联DG 现有架构:physical standby 一主二备,在此基础上,在主库下新建备库standby3.级联备库cascade 数据库版本 11.2.0.4 db_name=p ...

  4. ORACLE 11gR2 DG(Physical Standby)日常维护02

    环境:RHEL 6.5 + Oracle 11.2.0.4 三.监控DG的状态 3.1监控DG备库的状态 3.2监控主库传输日志链路的状态 四.备库切换为snapshot standby 4.1备库切 ...

  5. ORACLE 11gR2 DG(Physical Standby)日常维护01

    环境:RHEL 6.4 + Oracle 11.2.0.4 一.主备手工切换 1.1 主库,切换成备库并启动到mount 1.2 备库,切换成主库并启动到open 1.3 新的备库启动日志应用 二.重 ...

  6. 【原】Configuring Oracle Data Guard In Physical Standby Database

    作者:david_zhang@sh [转载时请以超链接形式标明文章] http://www.cnblogs.com/david-zhang-index/p/5042640.html参照文档:https ...

  7. ORACLE 11.2.0.4 Single To Single Data Guard 安装 physical standby

    [root@ORACLE ~]# su - oracle [oracle@ORACLE ~]$ sqlplus / as sysdba . 查看主库归档模式: SQL> select log_m ...

  8. DG - physical standby switchover切换过程

    一.切换前检查1.检查备库已经全部接收到主库的redo如果是最大可用性.最大保护性模式,可以在primary端查看v$archive_dest_status,确认是否所有的redo已经传送到备库#在主 ...

  9. [Oracle][DATAGUARD] PHYSICAL STANDBY环境里,使用CATALOG管理Primary和Standby

    1.先使用控制文件构筑好PHYSICAL STANDBY环境(Primary:Single 11.2.0.4,Standby Single 11.2.0.4) 2.构筑好Catalog用的服务器(Ca ...

随机推荐

  1. C++中的析构顺序和cosnt对象

    1,当程序中存在多个对象的时候,如何确定这些对象的析构顺序? 2,单个对象创建时构造函数的调用顺序(工程经验总结): 1,调用父类的构造过程: 2,调用成员变量的构造函数(调用顺序与声明顺序相同): ...

  2. [BZOJ 2154]Crash的数字表格(莫比乌斯反演+数论分块)

    [BZOJ 2154]Crash的数字表格(莫比乌斯反演+数论分块) 题面 求 \[\sum_{i=1}^{n} \sum_{j=1}^{m} \mathrm{lcm}(i,j)\] 分析 \[\su ...

  3. 使用before和after双伪元素清除浮动

    使用方法: .clearfix:before,.clearfix:after { content:"."; display:table; } .clearfix:after { c ...

  4. 小白学Python——Matplotlib 学习(3) 函数图形

    import matplotlib.pyplot as plt import numpy as np x = np.linspace(-1,1,50) y = 2*x + 1 plt.figure() ...

  5. CSUST 8.3 早训

    A - Settlers' Training CodeForces - 63B 题意 给你一串数字,相同的数字为一组,每次可以给一组中的一个数字加一,问这一串数字全变成K需要多少步? 题解 模拟 C+ ...

  6. P2510 [HAOI2008]下落的圆盘

    传送门 首先考虑两个圆覆盖的情况,我们可以求出圆心与交点连线 $A$ 的极角 具体就是求出两圆心连线 $B$ 极角加上余弦定理加反余弦求出 $A,B$ 之间夹角 ,然后覆盖了多少就可以得出 但是多个圆 ...

  7. The Preliminary Contest for ICPC Asia Xuzhou 2019 E. XKC's basketball team (线段树)

    题目链接:https://nanti.jisuanke.com/t/41387 题目大意:对于给定序列,求出对于每个位置求出比该数大于m的最靠右的位置. 思路:首先对序列进行离散化,然后对于每个数的下 ...

  8. 将数据转为tfrecord格式

    假设emo文件夹下,有1,2,3,4等文件夹,每个文件夹代表一个类别 import tensorflow as tf from PIL import Image from glob import gl ...

  9. apply_nodes_func

    import torch as th import dgl g=dgl.DGLGraph() g.add_nodes(3) g.ndata["x"]=th.ones(3,4) #n ...

  10. 浅析拯救小矮人的 nlogn 算法及其证明

    浅析拯救小矮人的 nlogn 算法及其证明 题型简介: 有 $ n $ 个人,第 $ i $ 个人身高 $ a_i $ 手长 $ b_i $ ,他们为了从一个高为 $ H $ 的洞中出去,决定搭人梯. ...