DG之主库、备库切换


一.开库与关库顺序

开库顺序

先启备库,再启主库(启动监听、打开告警日志)

关库顺序

先关主库,再关备库

二.主备库切换

1、操作过程一览

步骤1:启动备库、监听、告警;

步骤2:启动主库、监听、告警;

步骤3:主库(bj)查询信息

SQL>selectname,dbid,database_role,protection_mode from v$database;







步骤4:备库(sh)上做recover

SQL>recovermanaged standby database disconnect from session;

步骤5:备库上插入数据

SQL>insert into scott.emp1 select * from scott.emp;

报错

尽管备库处于open状态,但它是一个read-only状态。

步骤6:查看主库(bj)、备库(sh)日志是否一致

SQL>selectmax(sequence#) from v$archived_log where name is not null;

或SQL>selectmax(sequence#) from v$archived_log;

举例:

主库:

备库:

上图表明已经归档的最大序列号均为34,说明日志是同步的,能够进行主备库切换。

步骤7:主库(bj)下检查能否够切换

SQL>selectname,database_role,protection_mode,switchover_status from v$database;

switchover_status显示“TO STANDBY”表示同意做切换。

步骤8:备库(sh)下检查能否够切换

SQL>selectname,database_role,protection_mode,switchover_status from v$database;

说明:备库是不同意主动去切成主库的,NOT ALLOWED状态说明正常。

步骤9:检查主库(bj)上的会话

SQL>select username,sid from v$session where username is notnull;

查看是否仍实用户使用数据库,若仍有人使用,是不同意切换的,切换前要通知确保无用户使用。

步骤10:主库(bj)变为物理备库(sh)

若没有会话,将主库(bj)变为物理备库(sh)

SQL> ALTER DATABASECOMMIT TO SWITCHOVER TO PHYSICAL STANDBY;

若有会话的话,关闭会话,将主库(bj)变为物理备库(sh)

SQL>  alter database commit to switchover to physical standby withsession shutdown;

步骤11:关闭、重新启动之前的主库(bj)到mount状态

SQL> SHUTDOWN IMMEDIATE;

SQL> STARTUP MOUNT;

SQL> selectswitchover_status from v$database;

SWITCHOVER_STATUS

--------------------

TO PRIMARY

注:在这个时候,两个数据库都应该处于备库状态。

步骤12:查证备库的转换状态

SQL> SELECTSWITCHOVER_STATUS FROM V$DATABASE;

SWITCHOVER_STATUS

-----------------

TO_PRIMARY ——能够转换为主库,说明是备库状态

步骤13:将目标物理备库(sh)转换为主库

SQL> ALTER DATABASECOMMIT TO SWITCHOVER TO PRIMARY(WITHSESSION SHUTDOWN);

步骤14:完毕备库(sh)到主库转换,物理备库启动到open

若物理备库(bj)在近期一次启动时不是处于仅仅读模式 opened in read-only mode,直接将数据库打开,然后下一步。

SQL> select status fromv$instance;

STATUS

------------

MOUNTED

SQL> ALTER DATABASE OPEN;

SQL> select switchover_statusfrom v$database;

SWITCHOVER_STATUS

--------------------

TO STANDBY

若物理备库(bj)在近期一次启动时是仅仅读模式,则先将数据库正常关闭再起库。

SQL> SHUTDOWN IMMEDIATE;

SQL> STARTUP;

步骤15:在新备库(bj)上又一次开启日志应用

SQL> ALTER DATABASERECOVER MANAGED STANDBY DATABASE DISCONNECT FROM SESSION;

步骤16:在新的主库(sh)上切换日志,開始数据传输给备库

SQL> ALTER SYSTEM SWITCHLOGFILE;

SQL> /

SQL> select max(sequence#)from  v$archived_log;

MAX(SEQUENCE#)

--------------

56

SQL> col name for a50;

SQL> select  NAME ,SEQUENCE#  from v$archived_log; 查看归档日志

步骤17:在备库(bj)上查看归档,两值相等说明备库能收到日志

SQL> select max(sequence#)from  v$archived_log;

MAX(SEQUENCE#)

--------------

56

SQL> col name for a50;

SQL> select  NAME ,SEQUENCE#  from v$archived_log;  查看归档日志

2、总结主备库切换重点

主库

备库

查询是否能切换(应该显示同意)

备库查询是否能切换(应该显示不同意)

切换为物理备库

切换到mount状态

查看备库转换状态

转换为主库

切换到mount状态

启动到open

启动到open状态

开启日志应用

切换日志

查看归档序列号

查看归档序列号

查询状态:备库

查询状态:主库

***********************************************声明************************************************

原创作品,出自 “深蓝的blog” 博客,欢迎转载,转载时请务必注明出处(http://blog.csdn.net/huangyanlong)。

表述有错误之处,请您留言,不胜感激。

提醒:点击文件夹,更有助于您的查看。

*****************************************************************************************************



DG之主库、备库切换(物理备库)的更多相关文章

  1. 【Oracle】DG中物理备库、快照备库的相互转换

    一.物理备库切换快照备库 1. 如果正在运行日志应用,先停止 ALTER DATABASE RECOVER MANAGED STANDBY DATABASE CANCEL; 2. 确保数据库为MOUN ...

  2. 搭建实时同步data guard的最高可用-切换主备

    搭建实时同步data guard的最高可用-切换主备 首先保证主库在归档模式下:错过N次了 准备二台机器(hostname gw hosts ech0)host-only [root@node1 ~] ...

  3. GoldenGate 传统抽取进程随 DataGuard 主备快速切换的方案(ADG 模式)

    环境描述: 1.节点描述 节点 IP 节点描述 11.6.76.221 GG 抽取端 / DG 节点,数据库版本号为 Oracle-11.2.0.3,与 11.6.76.222 组成 DataGuar ...

  4. 物理DG主备库切换时遇到ORA-16139: media recovery required错误

    在物理DG主备库切换时遇到ORA-16139: media recovery required错误 SQL> ALTER DATABASE COMMIT TO SWITCHOVER TO PRI ...

  5. Flashing Back a Failed Primary Database into a Physical Standby Database(闪回FAILOVER失败的物理备库)

    文档操作依据来自官方网址:https://docs.oracle.com/cd/E11882_01/server.112/e41134/scenarios.htm#SBYDB4888 闪回FAILOV ...

  6. DG日志不应用,GAP,主备切换解决思路与办法

    环境ORACLE 10G OS WINDOWS 对于DG故障解决思路,DG日志切换不进行应用,DG出现GAP解决方法,DG主备库切换, 当DG出现故障时,第一时间检测alert日志,服务器OS日志,网 ...

  7. [terry笔记]11gR2_dataguard_主备库切换

    主备库切换  Switchover  一般SWITCHOVER切换都是计划中的切换,特点是在切换后,不会丢失任何的数据,而且这个过程是可逆的,整个DATA GUARD环境不会被破坏,原来DATA GU ...

  8. linux下oracle11G DG搭建(三):环绕备库搭建操作

    linux下oracle11G DG搭建(三):环绕备库搭建操作 环境 名称 主库 备库 主机名 bjsrv shsrv 软件版本号 RedHat Enterprise5.5.Oracle 11g 1 ...

  9. Spring Boot中自定义注解+AOP实现主备库切换

    摘要: 本篇文章的场景是做调度中心和监控中心时的需求,后端使用TDDL实现分表分库,需求:实现关键业务的查询监控,当用Mybatis查询数据时需要从主库切换到备库或者直接连到备库上查询,从而减小主库的 ...

随机推荐

  1. JS封装cookie操作函数实例(设置、读取、删除)

    本文实例讲述了JS封装cookie操作函数.分享给大家供大家参考,具体如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 ...

  2. OC基础17:归档

    "OC基础"这个分类的文章是我在自学Stephen G.Kochan的<Objective-C程序设计第6版>过程中的笔记. 1.归档即是用某种格式把一个或多个对象保存 ...

  3. 浏览器缓存相关http头

    近期看雅虎黄金34条,学习下优化站点性能的方法. 当中有一条:"为文件头指定Expires或Cache-Control",详细来说指对于静态内容:设置文件头过期时间Expires的 ...

  4. Winpcap网络编程九之Winpcap实战,ARP协议获得MAC表及主机通信

    大家好,本次我们须要完毕的任务是: 完毕两台主机之间的数据通信(数据链路层) 仿真ARP协议获得网段内主机的MAC表 使用帧完毕两台主机的通信(Hello! I'm -) 声明:本文章的目的是为大家的 ...

  5. 多线程中的lua同步问题

    最近写paintsnow::start时出现了一个非常麻烦的BUG,程序的Release版本大约每运行十几次就会有一次启动时崩溃(Debug版本还没崩溃过),崩溃点也不固定.经过简单分析之后,确定是线 ...

  6. 关于iconfont

    1. 从FONT-FACE说起 要想了解iconfont,得从一个新的css3规则说起.css3中,新增了一种样式规则,@font-face,这个规则可以用来引入自定义的字体,到客户端.以前,我们的字 ...

  7. [Python笔记][第二章Python序列-复杂的数据结构]

    2016/1/27学习内容 第二章 Python序列-复杂的数据结构 堆 import heapq #添加元素进堆 heapq.heappush(heap,n) #小根堆堆顶 heapq.heappo ...

  8. jquery中push()的用法(数组添加元素)

    push定义和用法 push() 方法可向数组的末尾添加一个或多个元素,并返回新的长度. 语法 arrayObject.push(newelement1,newelement2,....,newele ...

  9. (重要) html概念之 input:name与id详解

    实例: 带有两个文本字段和一个提交按钮的 HTML 表单: <form action="form_action.asp" method="get"> ...

  10. S - 骨牌铺方格(第二季水)

    Description          在2×n的一个长方形方格中,用一个1× 2的骨牌铺满方格,输入n ,输出铺放方案的总数.         例如n=3时,为2× 3方格,骨牌的铺放方案有三种, ...