热门标签 | 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)和非关系型数据库(如MongoDB)的基本操作及高级功能。通过三个阶段的学习路径——基础、优化和部署,帮助读者全面掌握数据库的使用和管理。 ... [详细]
  • 主调|大侠_重温C++ ... [详细]
  • 本文详细介绍了如何在Linux系统中创建和管理DB2数据库,包括用户切换、数据库创建、错误处理、连接与断开、表空间和缓冲池的创建,以及用户权限管理和数据导入导出等操作。 ... [详细]
  • MySQL锁机制详解
    本文深入探讨了MySQL中的锁机制,包括表级锁、行级锁以及元数据锁,通过实例详细解释了各种锁的工作原理及其应用场景。同时,文章还介绍了如何通过锁来优化数据库性能,避免常见的并发问题。 ... [详细]
  • 方法:1 配置数据库basediros.path.abspath(os.path.dirname(__file__))  #获取当前文件的绝对路径appFlask(__name__ ... [详细]
  • Netflix利用Druid实现高效实时数据分析
    本文探讨了全球领先的在线娱乐公司Netflix如何通过采用Apache Druid,实现了高效的数据采集、处理和实时分析,从而显著提升了用户体验和业务决策的准确性。文章详细介绍了Netflix在系统架构、数据摄取、管理和查询方面的实践,并展示了Druid在大规模数据处理中的卓越性能。 ... [详细]
  • 本文介绍 SQL Server 的基本概念和操作,涵盖系统数据库、常用数据类型、表的创建及增删改查等基础操作。通过实例帮助读者快速上手 SQL Server 数据库管理。 ... [详细]
  • 福克斯新闻数据库配置失误导致1300万条敏感记录泄露
    由于数据库配置错误,福克斯新闻暴露了一个58GB的未受保护数据库,其中包含约1300万条网络内容管理记录。任何互联网用户都可以访问这些数据,引发了严重的安全风险。 ... [详细]
  • 本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ... [详细]
  • 本文探讨了在 SQL Server 中使用 JDBC 插入数据时遇到的问题。通过详细分析代码和数据库配置,提供了解决方案并解释了潜在的原因。 ... [详细]
  • 本文深入探讨了 Oracle 数据库的网络配置,包括全局数据库名、实例名等关键参数的设置与作用,旨在为数据库管理员和开发人员提供全面的参考。 ... [详细]
  • 本文档介绍了如何在Visual Studio 2010环境下,利用C#语言连接SQL Server 2008数据库,并实现基本的数据操作,如增删改查等功能。通过构建一个面向对象的数据库工具类,简化了数据库操作流程。 ... [详细]
  • 如何在SQL Server 2008中通过Profiler跟踪特定数据库及获取客户端信息
    本文介绍如何利用SQL Server Profiler工具来监控特定数据库的操作,并获取执行这些操作的客户端计算机名和账户名。步骤包括创建新的跟踪、配置跟踪属性以及设置列筛选器以精确过滤数据。 ... [详细]
  • 请看|间隔时间_Postgresql 主从复制 ... [详细]
  • 本文详细介绍了如何在云服务器上配置Nginx、Tomcat、JDK和MySQL。涵盖从下载、安装到配置的完整步骤,帮助读者快速搭建Java Web开发环境。 ... [详细]
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社区 版权所有