介绍几种 MySQL 官方高可用方案

devtools/2024/9/22 23:49:35/

前言:

MySQL 官方提供了多种高可用部署方案,从最基础的主从复制到组复制再到 InnoDB Cluster 等等。本篇文章以 MySQL 8.0 版本为准,介绍下不同高可用方案架构原理及使用场景。

1.MySQL Replication

MySQL Replication 是官方提供的主从同步方案,用于实现数据从一个 MySQL 实例(称为源或主服务器,Master)自动复制到一个或多个其他 MySQL 实例(称为副本或从服务器,Slave)。是目前应用最广的 MySQL 容灾方案,也是一切高可用方案的基础。

Replication 用两个或以上的实例搭建了 MySQL 主从复制集群,主节点处理写操作,从节点异步或半同步复制数据。虽然功能相对简单,但通过设置多个从节点可以实现读写分离和一定程度的故障转移。

主要特性

  • 异步复制:默认情况下,MySQL 使用异步复制,主服务器在写入数据后即认为操作完成,而不等待从服务器确认。
  • 半同步复制:在半同步复制模式下,主服务器在提交事务时会等待至少一个从服务器确认接收到数据。
  • 延迟复制:可以配置从服务器延迟一定时间接收主服务器的数据,用于防止误操作等场景。

适用场景

  • 读密集型应用:在需要高读取性能的场景下,读写分离架构可以有效提升性能。
  • 数据备份和容灾:用作数据实时备份和故障恢复的场景。
  • 业务分布:适合对高可用要求不高的业务,允许丢数据及同步延迟。
2.MySQL Group Replication

MySQL Group Replication 即组复制,简称为 MGR 。是 MySQL 5.7 版本之后引入的一种高可用性和高扩展性的解决方案,基于原生复制技术和 Paxos 协议实现。它提供了高一致性、高容错性、高扩展性和高灵活性。可以使用单主模式或双主模式,集群一般至少由三个节点组成。

主要特性

  • 多主复制:允许多个节点同时处理读写请求,从而提高系统的吞吐量和可靠性。
  • 自动故障转移:当某个节点发生故障时,Group Replication 会自动重新配置集群,确保服务的连续性。
  • 强一致性:使用分布式协议确保数据在所有节点之间的一致性,避免数据冲突和不一致。
  • 冲突检测与解决:内置冲突检测机制,能够自动处理并解决数据冲突。

适用场景:

  • 高可用性需求:适用于需要高可用性和数据强一致性的场景。
  • 分布式系统:适用于需要分布式数据处理和高吞吐量的应用。
  • 自动化管理:适用于希望通过自动化工具简化管理和运维的企业。
3.MySQL InnoDB Cluster

MySQL InnoDB Cluster 是 MySQL 官方提供的一种原生高可用性和高可扩展性解决方案。它通过使用 Group Replication 来实现数据的自动复制和高可用性。并结合 MySQL Shell 及 MySQL Router ,提供了更全面的高可用解决方案,包括自动安装、配置、管理和监控 MySQL 集群的能力。架构示意图如下:

image.png

InnoDB Cluster 集群内部基于 MySQL 组复制构建,提供自动成员管理,容错,自动故障转移动能等。利用 MySQL Shell 提供的 AdminAPI 功能来管理和配置 InnoDB Cluster。利用 MySQL Router 提供路由功能, 将客户端应用程序透明地连接到服务器实例,如果服务器实例发生意外故障,集群会自动重新配置。

主要特性

  • 自动故障转移:在主节点出现故障时,系统可以自动将读写请求切换到可用的从节点,确保服务的连续性。
  • 强一致性:利用 Group Replication 确保所有节点的数据一致性。
  • 读写分离:支持读写分离,提高系统的读性能。
  • 简化管理:通过 MySQL Shell 和 AdminAPI 进行自动化管理,简化集群的部署和运维。

适用场景

  • 适用于需要高可用性、高一致性和高读性能的应用场景,推荐使用 MySQL 8.0 的高版本进行部署。
4.MySQL InnoDB ClusterSet

MySQL InnoDB ClusterSet 是在 InnoDB Cluster 基础上的扩展,旨在提供跨地域的高可用性和容灾能力。它集成多个 InnoDB Cluster,实现跨地域的数据复制和故障转移。

InnoDB ClusterSet 使用专用的 ClusterSet 复制通道自动管理从主集群到副本集群的复制。如果主集群由于数据中心损坏或网络连接丢失而变得无法使用,用户可以激活副本集群以恢复服务的可用性。

image.png

主要特性

  • 跨地域高可用:通过多个地理位置的集群实现跨地域的高可用性和容灾能力。
  • 一致性协调:ClusterSet Manager 统一管理和协调多个集群间的数据一致性和故障转移。
  • 异步复制:各个集群间的数据同步采用异步复制技术,确保数据在灾难情况下的快速恢复。

适用场景

  • 适用于需要跨地域部署和高可用的场景,如全球分布的业务系统、大型企业的多数据中心部署等。
5.MySQL InnoDB ReplicaSet

MySQL InnoDB ReplicaSet 是基于传统主从复制架构的高可用性方案,只是集成了 MySQL Shell 及 MySQL Router 进行配置及管理。InnoDB ReplicaSet 不提供 InnoDB Cluster 提供的所有功能,例如自动故障转移或多主模式。但是它确实支持以类似方式配置、添加和删除实例等功能。在主节点不可用的情况下,需要使用 AdminAPI 手动触发故障转移。

主要特性

  • 主从复制:基于异步复制技术,将数据从主节点复制到一个或多个从节点。
  • 手动故障转移:在主节点故障时需要手动进行故障转移。
  • 易于管理:架构相对简单,配置和管理较为方便。

适用场景

  • 适用于中小型企业的业务系统、开发和测试环境等不需要复杂高可用性和自动故障转移的场景。
6.几种方案对比

下面我们从几个不同维度来对比下这几种方案,以表格形式列出,更清晰明确。

image.png

这些方案各有特点,适用于不同的业务场景和需求。选择合适的高可用方案时,需要基于实际业务需求、技术实力、成本预算、数据一致性、写入性能、系统复杂度和运维成本等因素。

总结:

本篇文章介绍了 MySQL 官方提供的几种高可用方案,除此之外,还有其他借助中间件搭建的高可用方案,例如:MHA、MMM、及借助 Keepalived、ProxySQL、Orchestrator 等工具的其他高可用方案。总而言之,高可用方案虽多,选择时还是要基于实际业务需求出发,综合考虑多种因素。


http://www.ppmy.cn/devtools/57182.html

相关文章

【力扣】有效的字母异位词

🔥博客主页: 我要成为C领域大神🎥系列专栏:【C核心编程】 【计算机网络】 【Linux编程】 【操作系统】 ❤️感谢大家点赞👍收藏⭐评论✍️ 本博客致力于知识分享,与更多的人进行学习交流 给定两个字符串 s …

高性价比模块:LSYT201B语音模块学习使用

最近打算做个语音的项目,找到了深圳雷龙发展的LSY201B这款语音模块,写出来安利一下 程序源码:SuiXinSc/Speech-Module (github.com) 或者进入Q群找我获取 目录 一,简要介绍: 硬件参数: 1,处理…

【pearcmd】通过pearcmd.php 进行GetShell

https://cloud.tencent.com/developer/article/2204400 关于PHP 配置 register_argc_argv 小结 的一些研究文章。 应用例题 [NewStarCTF 2023 公开赛道]Include &#x1f350; <?phperror_reporting(0);if(isset($_GET[file])) {$file $_GET[file];if(preg_match(/flag|l…

力扣第218题“天际线问题”

在本篇文章中&#xff0c;我们将详细解读力扣第218题“天际线问题”。通过学习本篇文章&#xff0c;读者将掌握如何使用扫描线算法和堆来解决这一问题&#xff0c;并了解相关的复杂度分析和模拟面试问答。每种方法都将配以详细的解释&#xff0c;以便于理解。 问题描述 力扣第…

Android14之RRO资源文件替换策略(二百二十一)

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长! 优质专栏:Audio工程师进阶系列【原创干货持续更新中……】🚀 优质专栏:多媒体系统工程师系列【原创干货持续更新中……】🚀 优质视频课程:AAOS车载系统+AOSP…

密码学及其应用 —— 密码学的经典问题

1. 古典密码学问题 1.1 问题1&#xff1a;破解凯撒密码 1.1.1 问题 凯撒密码是最简单的单字母替换加密方案。这是一种通过将字母表中的字母固定向右移动几位来实现的加密方法。解密下面的文本&#xff0c;该文本通过对一个去除了空格的法语文本应用凯撒密码获得&#xff1a; …

3072. 将元素分配到两个数组中 II Hard

给你一个下标从 1 开始、长度为 n 的整数数组 nums 。 现定义函数 greaterCount &#xff0c;使得 greaterCount(arr, val) 返回数组 arr 中 严格大于 val 的元素数量。 你需要使用 n 次操作&#xff0c;将 nums 的所有元素分配到两个数组 arr1 和 arr2 中。在第一次操作中&a…

PostgreSQL匹配字符串方法

PostgreSQL匹配字符串方法 在 PostgreSQL 中&#xff0c;如果你想要检查一个包含多个由逗号分隔的值的字符串是否包含特定的子字符串&#xff0c;你可以使用字符串函数来实现这一点。由于你正在查找的是一个由逗号分隔的列表中的特定值&#xff0c;你需要确保在比较时该值不是…