iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Mysql之高可用方案浅析
  • 253
分享到

Mysql之高可用方案浅析

mysql高可用双机热备 2023-09-06 11:09:50 253人浏览 薄情痞子
摘要

在工程项目中,系统应用的高可用性越来越重要,业主越来越重视。其实高可用可以分为应用层高可用和数据层高可用,数据层高可用中常见的有关系型数据库Mysql的高可用、非关系型NoSQL数据库Redis的

在工程项目中,系统应用的高可用性越来越重要,业主越来越重视。其实高可用可以分为应用层高可用和数据层高可用,数据层高可用中常见的有关系型数据库Mysql的高可用、非关系型NoSQL数据库Redis的高可用等,下面聊聊典型的关系型数据库mysql的高可用方案。

1、单中心双机

单中心双机的常见方案如下:

  • 一主一备架构(主备)
  • 一主一从架构(主从)
  • 互为主从架构(双主)

1.1、一主一备

一主一备架构是双机部署中最简单的一种架构了,mysql数据库系统自带这个数据同步(主备)功能。
思路:将mysql数据库部署到两台机器,其中一台机器作为日常线上提供数据读写服务的机器,称为主机;另一台机器不提供线上服务,但会实时将主机的数据同步过来,称为备机。一旦主机出现了故障,通过人工的方式,手动将主机下线,将备机改为主机来继续提供服务。
优点:不需要做什么开发改造。
缺点:当主机出现故障的时候,需要人工去干预;还有就是需要一台备机长期备着,单又不提供线上服务,浪费资源。

1.2、一主一从

为了解决资源浪费的问题,出现了一主一从架构。
思路:一主一从架构与一主一备架构一样。区别就是一主一备的备机不提供线上服务,主要起到备份作用;而一主一从的备机改为了从机,也提供线上服务,但是只提供读服务,不提供写服务。
优点:相对一主一备架构,节约了资源,从机也在线提供读服务。当主机出现故障的时候,在人工介入之前,从机依旧可以提供读服务,可用性又提高了一个层次。
缺点:架构稍微复杂了一点,业务系统需要用一定的策略去判断该路由到那一台去读取数据,且数据同步会有延迟,去从机读取数据也可能会有延迟;还有就是并没有解决人工干预的问题,当主机出现了故障后还需要人工去处理。
若想让架构更智能一旦,需要引入一主一从自动切换功能,当主机出现故障后,从机能够自己检测发现,并自己将自己切换为主机,将原来的主机下线或转换为从机,即数据同步方向变了,但复杂度和成本加剧,不好实现。

1.3、互为主从

互为主从架构是指两台机器自己都是主机,并且也都是对方的从机,两台机器都提高完整的读写服务,无需切换。当应用系统在调用的时候随机挑选一台即可,当其中一台宕机了,另一台还可以继续服务。
思路:两台机器互为主从,都接受写数据,并将数据实时同步给对方,需要将数据进行两台机器的双向复制。通过VIP对外提供唯一一个服务地址,如通过keepalived组件实现ip漂移,当绑定的机器宕机了,漂移到另一台机器继续提供服务。
优点:解决了人工干预的问题,可用性得到进一步提高。
缺点:架构复杂度加剧,不可避免会有一定程度的数据延迟,极端情况下甚至会有数据丢失问题。

2、多机

常见的多机方案如下:

  • 单中心数据集群
  • 多中心数据分区

2.1、单中心数据集群

单数据中心多机器集群又分为:

  • 数据集中模式(一主多从);
  • 数据分散模式;

这两种的主要区别在于集群中的完整业务数据是全部集中在一台机器上,但是分散在多台机器上。

数据集中模式

这种模式与一主一从架构类似,完整的业务数据还是存储在一台主机上,主机承担读服务和写服务,从机只承担读服务。但是从机有多台机器,从机实时的从主机同步数据,称为一主多从模式。
因为有多个从机,带来了一些额外需要处理问题,比如:

  • 主机需要实时的将数据同步到多台从机上,涉及到主机的处理压力问题。
  • 需要保障多台从机之间的数据一致性的问题,如果出现数据不一致,如何处理。
  • 多台从机是如何检测主机状态的,因为从机在关键时刻是要替换主机的,那么如果多台从机监测到的主机状态不一致,那又可能会带来其它问题。
  • 从机切换为主机的时候,选择哪一台从机来切换呢,这涉及到多台从机之间如何进行选举的问题。

由于数据集中模式的所有写操作都只到一台主机上,而读操作可以到N台从机上。因此这种模式比较适用于业务数据量不大、读操作远远大于写操作、集群规模较小的业务场景。

数据分散模式

数据分散模式是指,完整的业务数据并非是全部存储在一台主机上的,而是由多台主机共同分担,分散存储。
使用这种模式,也有几点需要特别注意的:

  • 尽量将数据均衡的分散的各个机上,这样才能保证资源的均衡使用和性能的最佳。
  • 多台机器上的数据虽然不同,但是也需要互相进行数据的备份。
  • 要能动态的增加和删除节点,这样可以便于随时扩展,通常采用一致性HASH的方法。

这种模式适用于大数据量、集群规模较大的场景。

2.2、多中心数据分区

出于容灾的考虑,通常会在多个不同地区部署多套的数据集群。毕竟在国内运营商网络故障、光纤被铲断等事件还是不少的。轻则一个机房出问题,重则一个城市一个省份都可能故障。
多中心的数据分区架构,将数据按照一定的规则进行分区,部署在不同机房/城市里,且每一个分区都存储一部分数据,通过这种方式来保障数据和服务的可用性。
这种架构中需要考虑分区规则和备份规则,复杂度加剧,详细方案请参考大佬博客。

3、mysql双主+keepalived实现双机热备高可用

双主+keepalived是非常典型的mysql高可用方案,架构示意如下:
在这里插入图片描述
在主实例的keepalived中,增加检测本机mysql是否存活的脚本,如果检测mysql宕了,就会重启keepalived,从而使VIP漂移到从实例。

优点:部署简单,只有两个节点,没有主实例宕机后选主的问题;业务应用不需要开发改造。
缺点:云环境使用不了。
具体可以参考《浅入浅出keepalived+mysql实现高可用双机热备》博客。
该高可用方案也可以扩展到一主多从的场景,保证多从机器从主机器实时同步数据,利用keepalived等第三方软件同时使用,即可以用来监控数据库的健康,又可以执行一系列管理命令,如果主库发生故障,切换到备库后仍然可以继续使用数据库。

4、小结

mysql的高可用还有其他解决方案,如下:

  • MHA(Master High Avaliable) 是一款 MySQL 开源高可用程序,MHA 在监测到主实例无响应后,可以自动将同步最靠前的 Slave 提升为 Master,然后将其他所有的 Slave 重新指向新的 Master。MHA Manager会定时探测集群中的master节点,当master出现故障时,它可以自动将最新数据的slave提升为新的master,然后将所有其他的slave重新指向新的master,整个故障转移过程对应用程序完全透明。
  • PXC(Percona XtraDB Cluster)是一个完全开源的 MySQL 高可用解决方案。它将 Percona Server、Percona XtraBackup 与 Galera 库集成在一起,以实现多主复制的 MySQL 集群。任何节点宕机,集群都可以继续运行而不会丢失任何数据。

具体那种方案还需要考虑具体的应用场景,如当工程应用采用云平台时,平台也会提供mysql的高可用能力,如mysql容器化部署,且具有副本机制、节点宕了后快速拉起机制,也提供了mysql的高可用性。

来源地址:https://blog.csdn.net/leijie0322/article/details/130905260

您可能感兴趣的文档:

--结束END--

本文标题: Mysql之高可用方案浅析

本文链接: https://www.lsjlt.com/news/396936.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • oracle怎么查询当前用户所有的表
    要查询当前用户拥有的所有表,可以使用以下 sql 命令:select * from user_tables; 如何查询当前用户拥有的所有表 要查询当前用户拥有的所有表,可以使...
    99+
    2024-05-14
    oracle
  • oracle怎么备份表中数据
    oracle 表数据备份的方法包括:导出数据 (exp):将表数据导出到外部文件。导入数据 (imp):将导出文件中的数据导入表中。用户管理的备份 (umr):允许用户控制备份和恢复过程...
    99+
    2024-05-14
    oracle
  • oracle怎么做到数据实时备份
    oracle 实时备份通过持续保持数据库和事务日志的副本来实现数据保护,提供快速恢复。实现机制主要包括归档重做日志和 asm 卷管理系统。它最小化数据丢失、加快恢复时间、消除手动备份任务...
    99+
    2024-05-14
    oracle 数据丢失
  • oracle怎么查询所有的表空间
    要查询 oracle 中的所有表空间,可以使用 sql 语句 "select tablespace_name from dba_tablespaces",其中 dba_tabl...
    99+
    2024-05-14
    oracle
  • oracle怎么创建新用户并赋予权限设置
    答案:要创建 oracle 新用户,请执行以下步骤:以具有 create user 权限的用户身份登录;在 sql*plus 窗口中输入 create user identified ...
    99+
    2024-05-14
    oracle
  • oracle怎么建立新用户
    在 oracle 数据库中创建用户的方法:使用 sql*plus 连接数据库;使用 create user 语法创建新用户;根据用户需要授予权限;注销并重新登录以使更改生效。 如何在 ...
    99+
    2024-05-14
    oracle
  • oracle怎么创建新用户并赋予权限密码
    本教程详细介绍了如何使用 oracle 创建一个新用户并授予其权限:创建新用户并设置密码。授予对特定表的读写权限。授予创建序列的权限。根据需要授予其他权限。 如何使用 Oracle 创...
    99+
    2024-05-14
    oracle
  • oracle怎么查询时间段内的数据记录表
    在 oracle 数据库中查询指定时间段内的数据记录表,可以使用 between 操作符,用于比较日期或时间的范围。语法:select * from table_name wh...
    99+
    2024-05-14
    oracle
  • oracle怎么查看表的分区
    问题:如何查看 oracle 表的分区?步骤:查询数据字典视图 all_tab_partitions,指定表名。结果显示分区名称、上边界值和下边界值。 如何查看 Oracle 表的分区...
    99+
    2024-05-14
    oracle
  • oracle怎么导入dump文件
    要导入 dump 文件,请先停止 oracle 服务,然后使用 impdp 命令。步骤包括:停止 oracle 数据库服务。导航到 oracle 数据泵工具目录。使用 impdp 命令导...
    99+
    2024-05-14
    oracle
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作