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

逻辑备数据库的切换和故障转移

欢迎进入Oracle社区论坛,与200万技术人员互动交流进入本文描述如何执行包含逻辑备数据库的切换和故障转移。一、逻辑备数据库的切换当你执行切换,在主数据库和逻辑备数据库之间更改角色,总是在主数据库上发起切换并在逻辑备数据库上完成。这些步骤

欢迎进入Oracle社区论坛,与200万技术人员互动交流 >>进入 本文描述如何执行包含逻辑备数据库的切换和故障转移。 一、 逻辑备数据库的切换 当你执行切换,在主数据库和逻辑备数据库之间更改角色,总是在主数据库上发起切换并在逻辑备数据库上完成。这些步骤

欢迎进入Oracle社区论坛,与200万技术人员互动交流 >>进入

  本文描述如何执行包含逻辑备数据库的切换和故障转移。

  一、 逻辑备数据库的切换

  当你执行切换,在主数据库和逻辑备数据库之间更改角色,总是在主数据库上发起切换并在逻辑备数据库上完成。这些步骤必须以所描述的顺序执行,否则切换将不会成功。

  注:如果主数据库是RAC 数据库,确保除了一个以外关闭所有实例,并且在发起切换之前禁止相应的线程。类似地,如果逻辑备数据库是RAC 数据库,确保除了一个以外的所有实例关闭SQL 应用,并且在发起切换之前禁止相应的线程。一旦切换操作成功完成,你能重新允许这些线程并启动实例。虽然实例是关闭的,但是当它们重启时,角色更改将不会自动传递到这些实例。

  第 1 步在主数据库上检验是否有可能执行切换

  在当前的主数据库上,查询在主数据库上的 V$DATABASE 固定视图的SWITCHOVER_STATUS 列,以检验是否可能执行切换。

  例如:

  SQL> SELECT SWITCHOVER_STATUS FROM V$DATABASE;

  SWITCHOVER_STATUS

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

  TO STANDBY

  1 row selected。

  在 SWITCHOVER_STATUS 列中的TO STANDBY 或SESSIONS ACTIVE 的值指出可能切换主数据库到逻辑备角色。如果这些值之一没有显示,则检验Data Guard 配置是否正确起作用(例如,检验所有LOG_ARCHIVE_DEST_n 参数值是否正确指定)。

  第 2 步为切换准备当前主数据库

  要为逻辑备数据库角色准备当前主数据库,在主数据库上执行下面的 SQL 语句:

  SQL> ALTER DATABASE PREPARE TO SWITCHOVER TO LOGICAL STANDBY;

  这条语句通知当前主数据库,它将马上切换到逻辑备角色并开始从新的主数据库接收重做数据。你在主数据库上执行这个步骤,为接收LogMiner Multiversioned Data Dictionary记录在当前逻辑备数据库的重做流中做准备,如步骤3 中描述。如果这个操作成功,则 V$DATABASE.SWITCHOVER_STATUS 列中显示PREPARING SWITCHOVER 值。

  第 3 步为切换准备目标逻辑备数据库

  使用下面命令在作为切换目标的逻辑备数据库上建立 LogMiner Multiversioned Data Dictionary:

  SQL> ALTER DATABASE PREPARE TO SWITCHOVER TO PRIMARY;

  这条语句也在逻辑备数据库上开始重做传输服务 ,开始传送其重做数据到当前主数据库和Data Guard 配置中的其它备数据库。从这个逻辑备数据库接收重做数据的站点接收重做数据但不应用。

  依赖于完成的工作量和数据库的大小,切换需要花费一些时间来完成。

  当 LogMiner Multiversioned Data Dictionary 正在重做流中记录时,在逻辑备数据库上的V$DATABASE.SWITCHOVER_STATUS 最初显示PREPARING DICTIONARY。一旦这个成功完成,SWITCHOVER_STATUS 列显示PREPARING SWITCHOVER。

  第 4 步确保当前主数据库为将来的主数据库的重做流做好准备

  在你能完成主数据库到逻辑备角色的转换之前,通过查询主数据库上的V$DATABASE固定视图的SWITCHOVER_STATUS 列,检验LogMiner Multiversioned Data Dictionary 是否被主数据库接收到。没有收到LogMiner Multiversioned Data Dictionary,切换无法进行,因为当前的主数据库将不能解释从未来的主数据库发送的重做记录。SWITCHOVER_STATUS列显示了切换的过程。

  当查询返回 TO LOGICAL STANDBY 值,你能进行到步骤5。

  例如:

  SQL> SELECT SWITCHOVER_STATUS FROM V$DATABASE;

  SWITCHOVER_STATUS

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

  TO LOGICAL STANDBY

  1 row selected

  注:

  你能通过以下面的顺序执行下面的语句来取消切换操作:

  1.在主数据库上取消切换:

  SQL> ALTER DATABASE PREPARE TO SWITCHOVER CANCEL;

  2.在逻辑备数据库上取消切换:

  SQL> ALTER DATABASE PREPARE TO SWITCHOVER CANCEL;

  第 5 步切换主数据库到逻辑备数据库角色

  要完成主数据库到逻辑备数据库的角色转换,执行下面 SQL 语句:

  SQL> ALTER DATABASE COMMIT TO SWITCHOVER TO LOGICAL STANDBY;

  这条语句等待主数据库上的所有当前事务结束,并阻止任何新的用户开始新事务,并在切换将要提交的地方建立一个时间点。

  执行这条语句也将阻止用户对由逻辑备数据库维护的数据进行更改。要确保更快地执行,确保主数据库在执行切换语句之前处于安静的状态,没有更新活动(例如,要求所有用户暂时从主数据库退出登录)。你能查询V$TRANSACTIONS 视图以获得任何当前正在处理的事务的状态,这些事务可能延迟这条语句的执行。

  主数据库现在可以经历角色转换以运行到备数据库角色。

  当主数据库经历角色转换到逻辑备数据库角色时,你不需要关闭和重启数据库。

  第 6 步确保所有可用的重做应用到将要成为新的主数据库的目标逻辑备数据库上

  在你完成主数据库到逻辑备角色的角色转换,以及配置中的备数据库接收到切换通知之后,你应该检验切换通知是否被目标备数据库处理,通过查询目标备数据库上的V$DATABASE 固定视图的SWITCHOVER_STATUS 列。一旦所有可用的重做记录应用到逻辑备数据库,SQL 应用自动关闭以准备预料中的角色转换。

  SWITCHOVER_STATUS 值更新以显示切换中的过程。当状态为TO PRIMARY,你能进行步骤7。

  例如:

  SQL> SELECT SWITCHOVER_STATUS FROM V$DATABASE;

  SWITCHOVER_STATUS

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

  TO PRIMARY

  1 row selected

  第 7 步切换目标逻辑备数据库到主数据库角色

  在你希望切换到主角色的逻辑备数据库上,使用下面的 SQL 语句来切换逻辑备数据库到主角色:

  SQL> ALTER DATABASE COMMIT TO SWITCHOVER TO PRIMARY;

  没有必要关闭并重启在 Data Guard 配置中的任何逻辑备数据库。其它现有的逻辑备数据库将在切换完成后继续正常起作用。然而,所有现有的物理备数据库在切换后无法参与到Data Guard 配置中了。

  第 8 步在新的逻辑备数据库上开始SQL 应用

  在新的逻辑备数据库,开始 SQL 应用:

  SQL> ALTER DATABASE START LOGICAL STANDBY APPLY;

[1] [2]


推荐阅读
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • 本文详细介绍了在ASP.NET中获取插入记录的ID的几种方法,包括使用SCOPE_IDENTITY()和IDENT_CURRENT()函数,以及通过ExecuteReader方法执行SQL语句获取ID的步骤。同时,还提供了使用这些方法的示例代码和注意事项。对于需要获取表中最后一个插入操作所产生的ID或马上使用刚插入的新记录ID的开发者来说,本文提供了一些有用的技巧和建议。 ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • EPICS Archiver Appliance存储waveform记录的尝试及资源需求分析
    本文介绍了EPICS Archiver Appliance存储waveform记录的尝试过程,并分析了其所需的资源容量。通过解决错误提示和调整内存大小,成功存储了波形数据。然后,讨论了储存环逐束团信号的意义,以及通过记录多圈的束团信号进行参数分析的可能性。波形数据的存储需求巨大,每天需要近250G,一年需要90T。然而,储存环逐束团信号具有重要意义,可以揭示出每个束团的纵向振荡频率和模式。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • 本文介绍了在Win10上安装WinPythonHadoop的详细步骤,包括安装Python环境、安装JDK8、安装pyspark、安装Hadoop和Spark、设置环境变量、下载winutils.exe等。同时提醒注意Hadoop版本与pyspark版本的一致性,并建议重启电脑以确保安装成功。 ... [详细]
  • 使用在线工具jsonschema2pojo根据json生成java对象
    本文介绍了使用在线工具jsonschema2pojo根据json生成java对象的方法。通过该工具,用户只需将json字符串复制到输入框中,即可自动将其转换成java对象。该工具还能解析列表式的json数据,并将嵌套在内层的对象也解析出来。本文以请求github的api为例,展示了使用该工具的步骤和效果。 ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
  • 仙贝旅行是日本最大的旅游服务平台之一,为广大用户提供优质的日本定制游服务。随着用户数量的增长,仙贝旅行决定与智齿科技合作,全面替换原有客服系统,打造全新的在线客服体系。该体系具备多渠道快速接入的能力,让仙贝旅行轻松与各个渠道的接入用户完成沟通。同时,机器人与人工协同发力,提升客户服务水平。 ... [详细]
  • 本文介绍了一些Java开发项目管理工具及其配置教程,包括团队协同工具worktil,版本管理工具GitLab,自动化构建工具Jenkins,项目管理工具Maven和Maven私服Nexus,以及Mybatis的安装和代码自动生成工具。提供了相关链接供读者参考。 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了StartingzookeeperFAILEDTOSTART相关的知识,希望对你有一定的参考价值。下载路径:https://ar ... [详细]
  • 本文介绍了在Linux下安装和配置Kafka的方法,包括安装JDK、下载和解压Kafka、配置Kafka的参数,以及配置Kafka的日志目录、服务器IP和日志存放路径等。同时还提供了单机配置部署的方法和zookeeper地址和端口的配置。通过实操成功的案例,帮助读者快速完成Kafka的安装和配置。 ... [详细]
  • SAP羞辱国产软件商:技术停在10年前
    SAP中国研究院总裁芮祥麟表示,国产软件厂商过于热衷概念炒作,技术水平停留在10年前的客户端架构水平。他认为,国内厂商推出基于SOA的产品或转型SAAS模式是不可能的,研发新架构需要时间。当前最热门的概念是云计算,芮祥麟呼吁国产厂商应该潜心研发底层架构。 ... [详细]
author-avatar
错2502857987
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有