热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

DG之主库、备库切换(物理备库)

DG之主库、备库切换一.开库与关库顺序开库顺序先启备库,再启主库(启动监听、打开告警日志)关库顺序先关主库,再关备库二.主备库切换1、操作过程一览步骤1:启动备库、监听、告警;步骤2:启动主库、监听、告警;步骤3:主库(bj)查询信息SQ

DG之主库、备库切换 一.开库与关库顺序 开库顺序 先启备库,再启主库(启动监听、打开告警日志) 关库顺序 先关主库,再关备库 二.主备库切换 1、操作过程一览 步骤1:启动备库、监听、告警; 步骤2:启动主库、监听、告警; 步骤3:主库(bj)查询信息 SQ

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)。

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

提醒:点击目录,更有助于您的查看。

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


推荐阅读
  • 如何高效启动大数据应用之旅?
    在前一篇文章中,我探讨了大数据的定义及其与数据挖掘的区别。本文将重点介绍如何高效启动大数据应用项目,涵盖关键步骤和最佳实践,帮助读者快速踏上大数据之旅。 ... [详细]
  • 手机号码归属地查询服务由 WebXml.com.cn 提供,通过其 WEB 服务接口(http://webservice.webxml.com.cn/WebServices/MobileCodeWS.asmx)实现。该服务能够准确解析国内手机号码的归属地信息,适用于多种应用场景,如用户身份验证、市场分析等。 ... [详细]
  • 在使用Ubuntu系统时,有时会遇到APT软件源配置导致的网络连接问题。本文介绍了如何通过优化APT软件源配置来解决此类问题,特别是在执行`apt-get update`命令时出现的错误。通过更换更稳定的镜像源和调整相关设置,可以显著提升软件包的下载速度和稳定性。 ... [详细]
  • Java中处理NullPointerException:getStackTrace()方法详解与实例代码 ... [详细]
  • 本文深入剖析了jQuery的架构设计与实现原理。jQuery的总体结构采用了一个自执行匿名函数的形式,该函数接收`window`和`undefined`作为参数,并在内部定义了一个局部的jQuery副本,以确保其内部变量和方法不会污染全局命名空间。这种设计不仅提高了代码的封装性和安全性,还使得jQuery能够更好地与其他JavaScript库兼容。通过详细分析这一架构,读者可以更好地理解jQuery的核心机制及其高效运行的原理。 ... [详细]
  • UGUI:借鉴NGUI的事件监听机制实现高效交互设计
    在Unity中,UGUI借鉴了NGUI的事件监听机制,以实现高效且便捷的交互设计。通过采用类似NGUI的UIEventListener方法,UGUI不仅简化了UI开发流程,还提升了项目的整体性能和用户体验。经过一段时间的实际应用,我们发现这种机制在复杂项目中表现尤为出色,能够显著提高开发效率和代码可维护性。 ... [详细]
  • React 实现 Post 请求下载 PDF 文件的解决方案
    在 React 应用中实现通过 POST 请求下载 PDF 文件的功能,本文提供了完整的代码示例。具体实现包括设置状态以显示加载提示,并通过控制台日志记录下载索引,确保请求的正确性和用户体验。此外,还详细介绍了如何处理响应流并将其转换为可下载的 PDF 文件,适用于需要安全传输数据的场景。 ... [详细]
  • 近日,百度推出了一项新功能,允许用户通过搜索框直接登录邮箱,这一创新举措显著提升了用户体验。这不仅体现了百度在搜索引擎技术方面的持续进步,也为未来的搜索技术发展提供了重要启示。通过整合多种服务,搜索引擎正逐渐成为用户日常生活中的多功能平台,未来有望实现更多便捷的功能和服务。 ... [详细]
  • 在Ubuntu 13.04系统中,如果希望移除OpenJDK以优化Java环境配置,但尝试卸载`openjdk-7-jre`时遇到了问题。具体命令 `$ sudo apt-get purge openjdk-7-jre` 会显示如下提示信息: ... [详细]
  • 字节跳动深圳研发中心安全业务团队正在火热招募人才! ... [详细]
  • 本文探讨了深度学习技术的基本原理及其广泛应用。通过分析深度学习的核心算法和模型结构,文章详细介绍了该技术在图像识别、自然语言处理和语音识别等领域的实际应用。此外,还讨论了深度学习在医疗诊断、自动驾驶和金融预测等方面的发展潜力和挑战。 ... [详细]
  • 在Ubuntu 20.04 Linux系统中部署Git的详细步骤与最佳实践
    在Ubuntu 20.04 Linux系统中部署Git时,首先确保您的操作系统版本正确,并已以具备sudo权限的用户身份登录。推荐使用APT软件包管理器进行安装,这是最简便且可靠的方法。此外,遵循最佳实践,如定期更新Git版本和配置全局设置,可以进一步提升使用体验和安全性。 ... [详细]
  • 初探设计模式之代理模式:原理与应用解析
    在设计模式中,代理模式通过一个代理对象来控制对真实对象的访问。UML图展示了代理类(如MathProxy)维护了一个引用,使得代理能够访问实际的主题对象。代理模式不仅能够延迟初始化昂贵的对象,还能在访问前后添加额外的操作,如权限检查或日志记录。这种模式在远程服务调用、虚拟代理和智能引用等方面有广泛应用。 ... [详细]
  • CSS中的pointer-events属性详解与应用
    在CSS中,`pointer-events`属性是一个非常实用但常被忽视的功能。它主要用于控制元素是否响应鼠标事件。当一个元素覆盖在其他元素之上时,通过设置`pointer-events`属性,可以决定该元素是否能够接收鼠标点击、悬停等交互操作,从而实现更灵活的用户界面设计。例如,将`pointer-events`设置为`none`可以使元素透明地传递鼠标事件,方便实现复杂的叠加效果和交互逻辑。 ... [详细]
  • 本文详细解析了CSS背景属性的简写顺序,包括背景颜色、背景图像、背景重复方式、背景固定方式等关键要素,帮助开发者更好地理解和应用这一重要样式规则。通过具体示例和实际应用场景,文章深入探讨了每个属性在简写形式中的排列和作用,为前端开发提供了实用的参考。 ... [详细]
author-avatar
fjy69
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有