12c及以后 ADG主备切换

12c及以后 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 在主库上启动切换](#3.2 在主库上启动切换)
      • [3.3 打开新主库](#3.3 打开新主库)
      • [3.4 open新的备库](#3.4 open新的备库)
      • [3.5 新的备库上启动Redo Apply](#3.5 新的备库上启动Redo Apply)
    • 四、切换后检查
      • [4.1 主备检查进程情况](#4.1 主备检查进程情况)
      • [4.2 新主库查询通道是否有error](#4.2 新主库查询通道是否有error)
      • [4.3 备库观察传输和应用延迟](#4.3 备库观察传输和应用延迟)

一、概述

12c之后切换步骤,使用11g命令也是可以完成主备切换的。

二、切换前检查

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 复制代码
验证的项目包括:Redo Apply是否在切换目标上运行; 切换目标的发布版本是否为12.1或更高; 切换目标是否同步; 以及是否运行了MRP
SQL> ALTER DATABASE SWITCHOVER TO 备库的db_unique_name verify;

3.2 在主库上启动切换

sql 复制代码
SQL> ALTER DATABASE SWITCHOVER TO 备库的db_unique_name;

3.3 打开新主库

sql 复制代码
SQL> alter database open;

3.4 open新的备库

sql 复制代码
在新的备库执行以下SQL语句以只读方式打开
SQL> startup

3.5 新的备库上启动Redo Apply

sql 复制代码
SQL> ALTER DATABASE RECOVER MANAGED STANDBY DATABASE 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;
相关推荐
梅孔立1 分钟前
服务器不支持node.js16以上版本安装?用Docker轻松部署Node.js 20+环境运行Strapi项目
服务器·docker·node.js
wdfk_prog23 分钟前
[Linux]学习笔记系列 -- lib/dump_stack.c 栈回溯打印(Stack Trace Dumping) 内核调试与错误诊断的基石
linux·运维·服务器·c语言·笔记·学习
蓝倾97637 分钟前
小红书获取用户作品列表API接口操作指南
java·服务器·前端·python·电商开放平台·开放api接口
ITZHIHONH37 分钟前
FastGPT源码解析 Agent知识库文本资料处理详解和代码分析
数据库·ai编程
bantinghy1 小时前
RPC内核细节(转载)
linux·服务器·网络·网络协议·rpc
运维成长记2 小时前
linux 100个问答81~101 主要是k8s相关
linux·运维·服务器
旺小仔.2 小时前
Linux--线程
linux·运维·服务器
小蒜学长2 小时前
基于Spring Boot的火灾报警系统的设计与实现(代码+数据库+LW)
java·数据库·spring boot·后端
我言秋日胜春朝★2 小时前
【Linux网络编程】传输层协议-----UDP协议
linux·网络·udp
Mr. Cao code2 小时前
探索OpenResty:高性能Web开发利器
linux·运维·服务器·前端·nginx·ubuntu·openresty