热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

高可用与业务连续性

     有一次大会听运营商和金融行业等都对业务连续性提出了很高的要求。在保证一致性的前提下,尽可能短的减少停机时间。这个压

        有一次大会听运营商和金融行业等都对业务连续性提出了很高的要求。在保证一致性的前提下,尽可能短的减少停机时间。这个压力主要都是在数据库上。在灾难来临时候对数据库进行切换。我们平时说的高可用一般来说都是容灾的,其实对于性能来说不是直接的提升。主从两个数据库采用读写分离来缓解压力,属于间接提升。我还是那句话,提升性能还是靠SQL。当然我也不反对硬件提升来提升性能。只是反对不反思自己SQL一味的仅仅提升硬件。

    不同数据库切换方法不太一样,不同数据库切换的难易程度也不一样。我们先来说说最复杂的。

    要说哪种主备库切换最难,我接触下来是Oracle。以前一直使用的alter database switchover to xxx的命令。这个命令发出,备库会提升为主库。但是原来的主库就被关闭了,需要手工启动。其实可以通过DGMGRL命令做到完全自动化的。有图有真相,整个过程也就1分钟。也许看了这个大家觉得我刚说的切换最难也不难嘛。


    也许是会者不难,难者不会吧。不过Oracle的ADG以及DGMGRL的配置相比较其他数据库而言是多了不少参数的。

    下面说明MySQL的,MySQL架构不同方式不同。

    A场景 一主一备。这种架构,只能切换一次,一次切换过后就要重建备库。通常这种我们推荐官方的router+一主两备模式。在主动或者被动关闭主库后,router引流到配置的第一候选节点上完成切换。(这种候选节点一定要是可写的,否则要手工去掉只读属性)。至于HMA,我是不用的。有GTID以后还用这个干什么?换句话说5.6以后就不应该有它了。

   B场景 双主。由于互为主从,那么不存在数据库切换一说,是有keepalive引流到另外一个节点。

   C场景MGR。由于这个是配合router使用的。在8.0.22以后的强一致加持下,所以数据是一致的。中间件router引流即可。


    再说PG的,PG和Oracle类似,PG的流复制是主库到备库。原生的PG切换和Oracle的切换也类似,手动。我比较喜欢他这种touch standby.signal触发式切换,显得简单多了。

    如果是一个新手Oracle ADG切换可能心里没底,新手可能切换失败,或者没有把握来回反复切换。但是PG这个,新手也有信心。


   再说TiDB。这种天生分布式,不要切换。

   再说Oracle RAC,天生多点读写,不要切换。(存储坏了另说,这种要考虑的话就要RAC+ADG以及OGG了)


   最后,我从业多年,自己经手的数据库切换只存在于练习环境和讲课使用。正式环境其实都还算稳定,遇到问题重启一下也就行了,不用切换。只要硬件不坏,数据库一般来说都起得来(99.9%)。起不来再切换(只要不是恶搞删除文件的),都起得来。我很反感动不动就切换的,有可能是网络不稳定呢?有可能就是慢到一定程度短时间没响应呢?有可能就是短暂卡主了呢?,为了避免说是因为不会切换而不切换,特意说明了一下原理和做实验说明。

   希望大家的系统除了演练,永远用不到切换。


  


推荐阅读
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • MySQL索引详解与优化
    本文深入探讨了MySQL中的索引机制,包括索引的基本概念、优势与劣势、分类及其实现原理,并详细介绍了索引的使用场景和优化技巧。通过具体示例,帮助读者更好地理解和应用索引以提升数据库性能。 ... [详细]
  • 本文探讨了MariaDB在当前数据库市场中的地位和挑战,分析其可能面临的困境,并提出了对未来发展的几点看法。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 本文详细探讨了不同SQL数据库管理系统(DBMS)在限制输出结果、拼接字段和日期时间处理方面的函数差异。通过具体示例,帮助读者理解并掌握如何在不同DBMS中实现相同功能。 ... [详细]
  • Navicat Premium 15 安装指南及数据库连接配置
    本文详细介绍 Navicat Premium 15 的安装步骤及其对多种数据库(如 MySQL 和 Oracle)的支持,帮助用户顺利完成软件的安装与激活。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 本文探讨了适用于Spring Boot应用程序的Web版SQL管理工具,这些工具不仅支持H2数据库,还能够处理MySQL和Oracle等主流数据库的表结构修改。 ... [详细]
  • 本文详细介绍了如何通过多种编程语言(如PHP、JSP)实现网站与MySQL数据库的连接,包括创建数据库、表的基本操作,以及数据的读取和写入方法。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
author-avatar
SADFGHJKSADFV_565
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有