首页IT科技mysql常用高可用架构(MySQL常见的高可用架构)

mysql常用高可用架构(MySQL常见的高可用架构)

时间2025-05-05 09:44:47分类IT科技浏览3513
导读:概述: 高可用架构对于互联网服务基本是标配,无论是应用服务还是数据库服务都需要做到高可用。虽然互联网服务号称7天24小时不间断服务,但多多少少有一些时候服务不可用,比如某些时候网页打不开,百度不能搜索或者无法发微博,发微信等。对于一个系统而言,可能包含很多模块,比如前端应用,缓存,数据库...

概述:

高可用架构对于互联网服务基本是标配           ,无论是应用服务还是数据库服务都需要做到高可用           。虽然互联网服务号称7天24小时不间断服务                 ,但多多少少有一些时候服务不可用     ,比如某些时候网页打不开     ,百度不能搜索或者无法发微博                 ,发微信等                 。对于一个系统而言           ,可能包含很多模块     ,比如前端应用                ,缓存           ,数据库,搜索                ,消息队列等                ,每个模块都需要做到高可用,才能保证整个系统的高可用     。对于数据库服务而言           ,高可用可能更复杂                ,对用户的服务可用     ,不仅仅是能访问           ,还需要有正确性保证                 ,因此讨论数据库的高可用方案时     ,一般会同时考虑方案中数据一致性问题     。

1.基于共享存储的方案SAN

方案介绍:SAN(Storage Area Network)简单点说就是可以实现网络中不同服务器的数据共享     ,共享存储能够为数据库服务器和存储解耦                 。使用共享存储时                 ,服务器能够正常挂载文件系统并操作           ,如果服务器挂了     ,备用服务器可以挂载相同的文件系统                ,执行需要的恢复操作           ,然后启动MySQL           。

优点:

1.可以避免存储外的其它组件引起的数据丢失     。

2.部署简单,切换逻辑简单                ,对应用透明                。

3.保证主备数据的强一致           。 限制或缺点:

1.共享存储是单点                ,若共享存储挂了,则会丢失数据。

2.价格比价昂贵                。

2.基于磁盘复制的方案 MySQL+DRDB架构

通过DRBD基于block块的复制模式           ,快速进行双主故障切换                ,很大程度上解决主库单点故障问题                。

方案介绍:DRBD(Distributed Replicated Block Device)是一种磁盘复制技术     ,可以获得和SAN类似的效果。DBRD是一个以linux内核模块方式实现的块级别同步复制技术           。它通过网卡将主服务器的每个块复制到另外一个服务器块设备上           ,并在主设备提交块之前记录下来                。DRBD与SAN类似                 ,也是有一个热备机器     ,开始提供服务时会使用和故障机器相同的数据     ,只不过DRBD的数据是复制存储                 ,不是共享存储     。DRBD的架构图如下: 优点:

1.切换对应用透明           。

2.保证主备数据的强一致                 。 限制或缺点:

1.影响写入性能           ,由于每次写磁盘     ,实质都需要同步到网络服务器     。

2.一般配置两节点同步                ,可扩展性比较差     。

3.备库不能提供读服务           ,资源浪费                 。

3           、MySQL+MHA架构

MHA目前在Mysql高可用方案中应该也是比较成熟和常见的方案,它由日本人开发出来                ,在mysql故障切换过程中                ,MHA能做到快速自动切换操作,而且还能最大限度保持数据的一致性           。

优点:

1                、 代码开源           ,方便结合业务场景二次开发

2      、故障切换时                ,可以修复多个Slave之间的差异日志     ,最终使所有Slave保持数据一致           ,然后从中选择一个充当新的Master                 ,并将其它Slave指向它     。

3           、 可以灵活选择VIP方案或者全局目录数据库方案(更改Master IP映射)来进行切换                。 缺点:

1                、无法保证强一致     ,因为从故障Master上保存二进制日志并不总是可行     ,比如Master磁盘坏了                 ,或者SSH认证失败等           。

2      、只支持一主多从架构           ,要求一个复制集群中必须最少有三台数据库服务器     ,一主二从                ,即一台充当master           ,一台充当备用master,另外一台充当从库。

3     、采用全局目录数据库方案切换时                ,需要应用感知变化                ,因此对应用不透明,因此要保持切换对应用透明           ,依然依赖于VIP                。

4                、不适用于大规模集群部署                ,配置比较复杂                。

5           、MHA管理节点本身的HA无法保证。

4     、MySQL+MMM架构

MMM即Master-Master Replication Manager for MySQL(mysql主主复制管理器)     ,是关于mysql主主复制配置的监控                、故障转移和管理的一套可伸缩的脚本套件           。

优点:

1           、安全、稳定性较高           ,可扩展性好

2                、对服务器数量要求至少三台及以上

3                、双主热备模式                 ,读写分离     ,SLAVE集群可线性扩展(主从复制性要求较高)

4、 同样可实现读写分离                。 缺点:

读写分离需要在程序端解决     ,Master大批量写操作时会产生主从延时

服务器资源:

1           、至少五台PC Server                 ,2台MySQL主库           ,2台MySQL从库     ,1台MMM Monitor;

2                、1台MMM Monitor选择低配;

3      、如果不采用F5作为从库的负载均衡器                ,可用2台PC SERVER部署LVS或HAProxy+Keepalived组合来代替; 参考资料: https://www.likecs.com/show-855612.html https://www.jb51.net/article/83400.htm 官方文档: https://dev.mysql.com/doc/refman/8.0/en/mysql-innodb-cluster-introduction.html
声明:本站所有文章           ,如无特殊说明或标注,均为本站原创发布     。任何个人或组织                ,在未征得本站同意时                ,禁止复制           、盗用                、采集      、发布本站内容到任何网站     、书籍等各类媒体平台           。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理                 。

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
制作苹果系统安装u盘 apple(零成本打造苹果系统安装U盘 U盘重装苹果系统图文教程)