数据库作为最基础的数据存储服务之一,在存储系统中有着非常重要的地位,因此要求其具备高可用性无可厚非。能实现不同SLA(服务水平协定)的解决方案有很多种,这些方案可以保证数据库服务器在硬件或软件出现故障时服务继续可用。

高可用性需要解决的主要问题有两个,一个是如何实现数据共享或同步数据,另一个是如何处理failover。数据共享一般的解决方案是通过SAN(Storage Area Network)来实现,而数据同步可以通过rsync软件或DRBD技术来实现。failover的意思是指当服务器死机或出现错误时可以自动切换到其他备用服务器,不影响服务器上业务系统的运行。本文介绍目前比较成熟的MySQL高可用解决方案。

1、主从复制解决方案

这是MySQL自身提供的一种高可用解决方案,数据同步方法采用的是MySQL replication技术。MySQL replication技术就是一个日志的复制过程,在复制过程中一台服务器充当主服务器,而一台或多台其他服务器充当从服务器,简单说就是,从服务器到主服务器拉取二进制日志文件,然后再将日志文件解析成相应的SQL在从服务器上重新执行一遍主服务器的操作,通过这种方式保证数据的一致性。

MySQL replication技术仅仅提供了日志的同步执行功能,而从服务器只能提供读操作,并且当主服务器发生故障时,必须手动处理failover,通常的做法是将一台从服务器更改为主服务器。这种解决方案在一定程度上实现了MySQL的高可用性,可以实现90.000%的SLA。

为了达到更高的可用性,在实际的应用环境中,一般都采用MySQL replication技术配合高可用集群软件来实现自动failover,这种方式可以实现95.000%的SLA。

2、MMM高可用解决方案

MMM(Master-Master Replication Manager for MySQL)MySQL主主复制管理器,提供了MySQL主主复制配置的监控、故障转移和管理的一套可伸缩的脚本套件。在MMM高可用解决方案中,典型的应用是双主多从架构,通过MySQL replication技术可以实现两台服务器互为主从,且在任何时候只有一个节点可以写入,避免多点写入的数据冲突。同时,当可写的主节点故障时,MMM套件可以立刻监控到,然后将服务自动切换到另一个主节点,继续提供服务,从而实现MySQL的高可用。

MMM方案是目前比较成熟的MySQL高可用解决方案,可以实现99.000%的SLA。

3、Heartbeat/SAN高可用解决方案

此解决方案是借助第三方软硬件实现的,在这个方案中,处理failover的方式是高可用集群软件Heartbeat,它监控和管理各个节点间连接的网络,并监控集群服务,当节点出现故障或者服务不可用时,自动在其他节点启动集群服务。

在数据共享方面,通过SAN存储来共享数据,在正常状态下,集群主节点将挂载存储进行数据读写,而当集群发生故障时,Heartbeat会首先通过一个仲裁设备将主节点挂载的存储设备释放,然后在备用节点上挂载存储,接着启动服务,通过这种方式实现数据的共享和同步。这种数据共享方式实现简单,但是成本较高,并且存在脑裂的可能,需要根据实际应用环境来选择。这种方案可以实现99.990%的SLA。

4、Heartbeat/DRBD高可用解决方案

这种高可用解决方案也是借助第三方软硬件实现的,在处理failover的方式上依旧采用Heartbeat,不同的是,在数据共享方面,采用了基于块级别的数据同步软件DRBD来实现。

DRBD(Distributed Replicated Block Device)是一个用软件实现的、无共享的、服务器之间镜像块设备内容的存储复制解决方案。和SAN网络不同,它并不共享存储,而是通过服务器之间的网络复制数据。这种方案实现起来稍微复杂,同时也存在脑裂的问题,可以实现99.900%的SLA。

5、MySQL Cluster高可用解决方案

MySQL Cluster由一组服务节点构成,每个服务节点上均运行着多种进程,包括MySQL服务器、NDB Cluster的数据节点、管理服务器,以及(可能)专门的数据访问程序。此解决方案是MySQL官方主推的技术方案,功能强大,但是由于实现较为繁琐,配置麻烦,企业实际应用并不多。MySQL Cluster的标准版和电信版可以达到99.999%的SLA。

本文内容不用于商业目的,如涉及知识产权问题,请权利人联系博为峰小编(021-64471599-8017),我们将立即处理

MySQL主流高可用解决方案有_高可用MySQL解决方案概述相关推荐

  1. mysql 聚合函数内比较运算符_关于常用 MYSQL 聚合函数,其他函数 ,类型转换,运算符 总结...

    /* 关于MYSQL 聚合函数,其他函数 ,类型转换,运算符 总结,*/ -- 1 运算符优先级  /* 12.1.1. 操作符优先级 以下列表显示了操作符优先级的由低到高的顺序.排列在同一行的操作符 ...

  2. mysql修改表结构大表_在线修改MySQL大表的表结构

    由于某个临时需求,需要给在线MySQL的某个超过千万的表增加一个字段.此表在设计之时完全按照需求实现,并没有多余的保留字段. 我们知道在MySQL中如果要执行ALTER TABLE操作,MySQL会通 ...

  3. 自动清理mysql的lock进程的脚本_自动清理MySQL的Lock进程的脚本

    自动清理MySQL的Lock进程的脚本 作者:小涵 | 来源:互联网 | 2018-07-13 21:01 阅读: 915 最近数据库服务器在某一时段进程数忽然暴增,导致数据库服务器死掉,根据日志查询 ...

  4. mysql 中文排序是什么规则_什么是 MySQL 的排序规则(Collation)?

    什么是 MySQL 的排序规则(Collation)? 马富天 2020-01-19 14:56:58 15 [摘要]当我们在使用 navicate for mysql 等第三方客户端管理界面新建一个 ...

  5. 详解mysql数据库的启动与终止_详解MySQL数据库的启动与终止(一)

    由于MySQL服务器具有多种安装分发,而且能够运行在多种操作平台之上,因此它的启动与停止的方法也多种多样.你可以根据实际情况使用其中的一种.在你安装.升级或者维护系统时,你可能需要多次启动和终止服务器 ...

  6. sae mysql 同步本地_MYSQL入门之三_将本地MySQL数据导入SAE数据库_MySQL

    bitsCN.com MYSQL入门之三_将本地MySQL数据导入SAE数据库 1. MySQL字符集 MySQL的默认字符集是latin1,将本地MySQL库导出成sql,再导入到SAE的MySQL ...

  7. mysql双机热备 读写分离_轻松搭建MySQL主从复制、读写分离双机热备)

    注意:如果此步骤始终为空设置(0.00秒),则表示先前的my.cnf配置不正确,请返回并重试检查配置步骤. (从)数据库中的配置 1.修改从属库的数据库配置文件 [root @ localhost]# ...

  8. mysql数据库+易语言的应用_易语言mysql数据应用源码

    易语言mysql数据应用源码 易语言mysql数据应用源码 系统结构:注册账号,连接Mysql,用户注册验证码,修改密码验证码,忘记密码验证码,修改密码,忘记密码, ======窗口程序集1 | | ...

  9. mysql 查询用户最后登陆时间_弄懂mysql:mysql的通信协议

    我准备从mysql的实现出发,将mysql好好理解一下,从他的逻辑结构一层一层出发,感受一下,所以再学第一层之前,要先对mysql整体的逻辑结构有一个初步认识 mysql逻辑架构 整体来说,MySql ...

最新文章

  1. .NET 调用c++库注意事项
  2. 【NLP】在机器学习中开发情感分析器的5种方法
  3. Pycharm、Idea、Goland 官方汉化来了
  4. JavaMail发送和接收邮件
  5. MyBatis 哪些地方用到了代理模式?
  6. 关于 SAP 电商云 Spartacus UI SSR 的 state transfer 问题
  7. scss-@extend
  8. XidianOJ 1099 A simple problem
  9. sublime3运行python_sublime中按ctrl+B调用python3运行
  10. MathType输入框怎么调整
  11. 大数据可视化平台可以实现什么功能
  12. Leetcode 27 Remove Element
  13. html js注册表单代码,用户注册常用javascript代码
  14. 唐宇迪学习笔记9:逻辑回归与梯度下降策略
  15. 导入从postman导出的json接口文件,并设置全局变量
  16. 量子力学中常用的微积分知识归纳
  17. fiddler软件抓包工具超详细配置方法
  18. 如何清除计算机的u盘使用记录,如何消除电脑上U盘使用记录
  19. Response.AddHeader 参数
  20. H5标签input标签上传文件(图片)

热门文章

  1. 红米k30s和k30u哪个好?
  2. python画鸟_最适合小白学的花色玩Python折线图|画个天气预报
  3. 【遥感图像处理】什么是亚像素,超像素?
  4. 电容的种类及使用注意事项
  5. 定时采用ajax方式获得数据库,ajax定时刷新数据库
  6. Syncing文件同步工具(详解)
  7. kubernetes安装Kuboard
  8. 管理类联考——逻辑——技巧篇——形式逻辑——考官出题套路
  9. 如何遍历 HashMap,遍历HashMap 的 5 种最佳方式
  10. JavaScript获得页面卷起的高度