11g ADG主备切换步骤

11g ADG主备切换 - 目录

    • 一、概述
    • 二、切换前检查
      • [2.1 检查传输通道和GAP](#2.1 检查传输通道和GAP)
      • [2.2 检查延迟时间](#2.2 检查延迟时间)
      • [2.3 检查主库VDATABASE.SWITCHOVER_STATUS](#2.3 检查主库VDATABASE.SWITCHOVER_STATUS)
    • 三、开始切换
      • [3.1 主库切换为备库](#3.1 主库切换为备库)
      • [3.2 重启原主库到mount](#3.2 重启原主库到mount)
      • [3.3 主库查询VDATABASE.SWITCHOVER_STATUS](#3.3 主库查询VDATABASE.SWITCHOVER_STATUS)
      • [3.4 备库切换为主库](#3.4 备库切换为主库)
      • [3.5 打开新主库](#3.5 打开新主库)
      • [3.6 在新备库打开mrp](#3.6 在新备库打开mrp)
    • 四、切换后检查
      • [4.1 主备检查进程情况](#4.1 主备检查进程情况)
      • [4.2 新主库查询通道是否有error](#4.2 新主库查询通道是否有error)
      • [4.3 备库观察传输和应用延迟](#4.3 备库观察传输和应用延迟)

一、概述

主备切换:11g切换时,如果主库为RAC,需要关闭其它实例,仅保留一个即可,12c以后可以不用关闭实例

二、切换前检查

2.1 检查传输通道和GAP

sql 复制代码
备库执行
SQL> SELECT STATUS, GAP_STATUS FROM V$ARCHIVE_DEST_STATUS WHERE DEST_ID = 2;

2.2 检查延迟时间

sql 复制代码
备库执行,延迟尽可能等于0
SQL> COLUMN NAME FORMAT A24
SQL> COLUMN VALUE FORMAT A16     
SQL> COLUMN DATUM_TIME FORMAT A24
SQL> SELECT NAME, VALUE, DATUM_TIME FROM V$DATAGUARD_STATS;

2.3 检查主库V$DATABASE.SWITCHOVER_STATUS

sql 复制代码
查询结果为to standby/session active,可以准备切换成备库
SQL> SELECT SWITCHOVER_STATUS FROM V$DATABASE;

三、开始切换

3.1 主库切换为备库

sql 复制代码
SQL> ALTER DATABASE COMMIT TO SWITCHOVER TO PHYSICAL STANDBY WITH SESSION SHUTDOWN;

3.2 重启原主库到mount

sql 复制代码
执行完3.1步骤后,主库默认已经关闭了
SQL> shutdown immediate
SQL> startup mount

3.3 主库查询V$DATABASE.SWITCHOVER_STATUS

sql 复制代码
检查结果应该为TO_PRIMARY或SESSIONS ACTIVE
SQL> SELECT SWITCHOVER_STATUS FROM V$DATABASE;

3.4 备库切换为主库

sql 复制代码
SQL> ALTER DATABASE COMMIT TO SWITCHOVER TO PRIMARY WITH SESSION SHUTDOWN;

3.5 打开新主库

sql 复制代码
SQL> ALTER DATABASE OPEN;

3.6 在新备库打开mrp

sql 复制代码
SQL> alter database open;
SQL> ALTER DATABASE RECOVER MANAGED STANDBY DATABASE USING CURRENT LOGFILE DISCONNECT FROM SESSION;

四、切换后检查

4.1 主备检查进程情况

sql 复制代码
SQL> col group_# for a5
SQL> col client_pid for a8
SQL> set line 250 pagesize 9999
SQL> SELECT A.INST_ID,A.PROCESS,A.STATUS,A.CLIENT_PROCESS,A.CLIENT_PID,A.GROUP# GROUP_#,A.THREAD#,A.SEQUENCE#,A.DELAY_MINS,
A.RESETLOG_ID,C.SID,C.SERIAL#,A.PID SPID,B.PNAME FROM GV$MANAGED_STANDBY A, GV$PROCESS B, GV$SESSION C
WHERE A.PID = B.SPID AND B.ADDR = C.PADDR AND A.INST_ID = B.INST_ID AND B.INST_ID = C.INST_ID ORDER BY A.INST_ID,B.PNAME;

4.2 新主库查询通道是否有error

sql 复制代码
SQL> set line 300
SQL> col DEST_NAME for a60
SQL> select dest_name,status,error from gv$archive_dest;

4.3 备库观察传输和应用延迟

sql 复制代码
SQL> COLUMN NAME FORMAT A24
SQL> COLUMN VALUE FORMAT A16     
SQL> COLUMN DATUM_TIME FORMAT A24
SQL> SELECT NAME, VALUE, DATUM_TIME FROM V$DATAGUARD_STATS;
相关推荐
戒不掉的伤怀13 分钟前
【Navicat 连接MySQL时出现错误1251:客户端不支持服务器请求的身份验证协议;请考虑升级MySQL客户端】
服务器·数据库·mysql
cv高级工程师YKY18 分钟前
服务器 - - QPS与TPS介绍
数据库
nbsaas-boot26 分钟前
高可扩展属性建模设计:架构师的全局思考与落地方案
数据库
爱上语文1 小时前
Redis基础(5):Redis的Java客户端
java·开发语言·数据库·redis·后端
陈敬雷-充电了么-CEO兼CTO1 小时前
推荐算法系统系列>推荐数据仓库集市的ETL数据处理
大数据·数据库·数据仓库·数据挖掘·数据分析·etl·推荐算法
MeshddY2 小时前
(超详细)数据库项目初体验:使用C语言连接数据库完成短地址服务(本地运行版)
c语言·数据库·单片机
wuxinyan1232 小时前
Java面试题033:一文深入了解MySQL(5)
java·数据库·mysql·面试
萧曵 丶2 小时前
Spring @TransactionalEventListener
java·数据库·spring·事务·transactional·异步
胡斌附体2 小时前
mobaxterm终端sqlplus乱码问题解决
数据库·乱码·sqlplus·字符集设置
moon66sun2 小时前
开源项目XYZ.ESB:数据库到数据库(DB->DB)集成
数据库·esb