2.MySQL 部署模式总结

一、MySQL 部署模式选型要求

我们在考虑MySQL数据库的高可用的架构时,主要要考虑如下几方面:

1、容灾  如果数据库发生了宕机或者意外中断等故障,能尽快恢复数据库的可用性,尽可能的减少停机时间,保证业务不会因为数据库的故障而中断。

2、备份数据一致性  用作备份、只读副本等功能的非主节点的数据应该和主节点的数据实时或者最终保持一致。

3、主从切换数据一致性  当业务发生数据库切换时,切换前后的数据库内容应当一致,不会因为数据缺失或者数据不一致而影响业务。

4、实时性  数据库主备库数据是否实时一致

二、MySQL复制方式介绍

MySQL基础复制有三种模式:异步复制/同步复制/半同步复制,3种模式各有利弊,下面对各种复制模式的优缺点做个简要的介绍。

1、异步复制(Asynchronous replicaton)

这是MySQL默认的复制模式,异步复制指主库写binlog、从库I/O线程读binlog并写入relaylog、从库SQL线程重放事务这三步之间是异步的。异步复制的优点是主库不需要关心备库的状态,主库不保证事务被传输到从库,如果主库崩溃,某些事务可能还未发送到从库,切换后可能导致事务的丢失。其优点是可以有更高的吞吐量,缺点是不能保持数据实时一致,不适合要求主从数据一致性要求较高的应用场景。

2、同步复制(Synchronous replicaton)

同步复制的模式下,主库在提交事务前,必须确认事务在所有的备库上都已经完成提交。即主库是最后一个提交的,在提交前需要将事务传递给从库并完成重放、提交等一系列动作。其优点是任何时候主备库都是一致的,主库的崩溃不会丢失事务,缺点是由于主库需要等待备库先提交事务,吞吐量很低。

3、半同步复制(Semisynchronous replicaiton)

MySQL从5.5开始引入了半同步复制,半同步复制介于异步复制和同步复制之间。主库在提交事务时先等待,必须确认至少一个从库收到了事件(从库将事件写入relaylog,不需要重放和提交,并向主库发送一个确认信息ACK),主库收到确认信息后才会正式commit。

与同步复制相比,半同步复制速度快很多,因为他只需要至少1个从库确认写入relaylog,并不需要完成在从库上的事务提交,同时又比异步复制更安全,因为主库在提交时,事务至少已经存在2个地方(主库的binlog和从库的relaylog)。由于半同步复制在提交事务前,需要从库返还确认信息,所以这里涉及到网络的往返通信开销,因此半同步复制只适合在网络条件较好的且地理上距离不远的环境部署,否则可能会因为网络延迟大幅降低主库性能。

三、主主半同步方案

使用双节点数据库(主库),搭建单向或者双向的半同步复制。在5.7以后的版本中,由于lossless、 replication、logical多线程复制等一些列新特性的引入,使得MySQL原生半同步复制更加可靠。

常见架构如下

 通常会和proxy、keepalived等第三方软件同时使用,即可以用来监控数据库的健康,又可以执行一系列管理命令。如果主库发生故障,切换到备库后仍然可以继续使用数据库。

优点:

1、架构比较简单,使用原生半同步复制作为数据同步的依据;

2、双节点,没有主机宕机后的选主问题,直接切换即可;

3、双节点,需求资源少,部署简单;

缺点:

1、完全依赖于半同步复制,如果半同步复制复制延时,数据实时一致性无法得到保证;

2、需要额外考虑haproxy、keepalived的高可用机制。

四、高可用架构方案

将双节点数据库扩展到多节点数据库,或者多节点数据库集群。可以根据自己的需要选择一主两从、一主多从或者多主多从的集群。

由于半同步复制,存在接收到一个从机的成功应答即认为半同步复制成功的特性,所以多从半同步复制的可靠性要优于单从半同步复制的可靠性。并且多节点同时宕机的几率也要小于单节点宕机的几率,所以多节点架构在一定程度上可以认为高可用性是好于双节点架构。

但是由于数据库数量较多,所以需要数据库管理软件来保证数据库的可维护性。可以选择MMM、MHA或者各个版本的proxy等等。常见方案如下:

1、MHA+多节点集群技术选型

 MHA Manager会定时探测集群中的master节点,当master出现故障时,它可以自动将最新数据的slave提升为新的master,然后将所有其他的slave重新指向新的master,整个故障转移过程对应用程序完全透明。

MHA Node运行在每台MySQL服务器上,主要作用是切换时处理二进制日志,确保切换尽量少丢数据。

MHA也可以扩展到如下的多节点集群:

优点:

  1. 可以进行故障的自动检测和转移;

  2. 可扩展性较好,可以根据需要扩展MySQL的节点数量和结构;

  3. 相比于双节点的MySQL复制,三节点/多节点的MySQL发生不可用的概率更低

缺点:

  1. 至少需要三节点,相对于双节点需要更多的资源;

  2. 逻辑较为复杂,发生故障后排查问题,定位问题更加困难;

  3. 数据一致性仍然靠原生半同步复制保证,仍然存在数据不一致的风险;

  4. 可能因为网络分区发生脑裂现象;

2、zookeeper+proxy技术选型

Zookeeper使用分布式算法保证集群数据的一致性,使用zookeeper可以有效的保证proxy的高可用性,可以较好的避免网络分区现象的产生。

优点:

  1. 较好的保证了整个系统的高可用性,包括proxy、MySQL;

  2. 扩展性较好,可以扩展为大规模集群;

缺点:

  1. 数据一致性仍然依赖于原生的mysql半同步复制;

  2. 引入zk,整个系统的逻辑变得更加复杂;

五、共享存储方案

共享存储实现了数据库服务器和存储设备的解耦,不同数据库之间的数据同步不再依赖于MySQL的原生复制功能,而是通过磁盘数据同步的手段,来保证数据的一致性。

1、SAN共享储存

SAN的概念是允许存储设备和处理器(服务器)之间建立直接的高速网络(与LAN相比)连接,通过这种连接实现数据的集中式存储。常用架构如下:

使用共享存储时,MySQL服务器能够正常挂载文件系统并操作,如果主库发生宕机,备库可以挂载相同的文件系统,保证主库和备库使用相同的数据。

优点:

  1. 两节点即可,部署简单,切换逻辑简单;

  2. 很好的保证数据的强一致性;

  3. 不会因为MySQL的逻辑错误发生数据不一致的情况;

缺点:

  1. 需要考虑共享存储的高可用;

  2. 价格昂贵;

2、DRBD磁盘复制

DRBD是一种基于软件、基于网络的块复制存储解决方案,主要用于对服务器之间的磁盘、分区、逻辑卷等进行数据镜像,当用户将数据写入本地磁盘时,还会将数据发送到网络中另一台主机的磁盘上,这样的本地主机(主节点)与远程主机(备节点)的数据就可以保证实时同步。常用架构如下:

 当本地主机出现问题,远程主机上还保留着一份相同的数据,可以继续使用,保证了数据的安全。

DRBD是linux内核模块实现的快级别的同步复制技术,可以与SAN达到相同的共享存储效果。

优点:

  1. 两节点即可,部署简单,切换逻辑简单;

  2. 相比于SAN储存网络,价格低廉;

  3. 保证数据的强一致性;

缺点:

  1. 对io性能影响较大;

  2. 从库不提供读操作;

六、分布式协议【常用方案】

分布式协议可以很好解决数据一致性问题。比较常见的方案如下:

1、MySQL cluster

MySQL cluster是官方集群的部署方案,通过使用NDB存储引擎实时备份冗余数据,实现数据库的高可用性和数据一致性。

优点:

  1. 全部使用官方组件,不依赖于第三方软件;

  2. 可以实现数据的强一致性;

缺点:

  1. 国内使用的较少;

  2. 配置较复杂,需要使用NDB储存引擎,与MySQL常规引擎存在一定差异;

  3. 至少三节点;

2、Galera

基于Galera的MySQL高可用集群, 是多主数据同步的MySQL集群解决方案,使用简单,没有单点故障,可用性高。常见架构如下:

 优点:

  1. 多主写入,无延迟复制,能保证数据强一致性;

  2. 有成熟的社区,有互联网公司在大规模的使用;

  3. 自动故障转移,自动添加、剔除节点;

缺点:

  1. 需要为原生MySQL节点打wsrep补丁

  2. 只支持innodb储存引擎

  3. 至少三节点;

3、POAXS协议【常用方案】

Paxos 算法解决的问题是一个分布式系统如何就某个值(决议)达成一致。这个算法被认为是同类算法中最有效的。Paxos与MySQL相结合可以实现在分布式的MySQL数据的强一致性。常见架构如下:

优点:

  1. 多主写入,无延迟复制,能保证数据强一致性;

  2. 有成熟理论基础;

  3. 自动故障转移,自动添加、剔除节点;

缺点:

  1. 只支持innodb储存引擎

  2. 至少三节点;

七、总结

随着人们对数据一致性的要求不断的提高,越来越多的方法被尝试用来解决分布式数据一致性的问题,如MySQL自身的优化、MySQL集群架构的优化、Paxos、Raft、2PC算法的引入等等。

而使用分布式算法用来解决MySQL数据库数据一致性的问题的方法,也越来越被人们所接受,一系列成熟的产品如PhxSQL、MariaDB Galera Cluster、Percona XtraDB Cluster等越来越多的被大规模使用。

随着官方MySQL Group Replication的GA,使用分布式协议来解决数据一致性问题已经成为了主流的方向。期望越来越多优秀的解决方案被提出,MySQL高可用问题可以被更好的解决。

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 图书管理程序基于MVC(Model-View-Controller)设计模式,该模式将图书管理系统分为三个主要部分,即模型(Model)、视图(View)和控制器(Controller)。这种分层结构使得程序编写更加可维护、可扩展,并且易于理解。 首先,使用开发工具IDEA来编写程序代码。IDEA是一种强大的集成开发环境,具有丰富的功能和工具,可以提高开发效率。通过IDEA,我们可以方便地编写、调试和测试程序。 其次,MySQL是我们选择的数据库管理系统,用于存储和管理图书信息。通过MySQL,我们可以创建适当的表结构,并实现对数据的增删改查操作。这样,我们可以方便地存储和管理大量的图书信息。 最后,我们使用Tomcat作为应用服务器来部署和运行图书管理程序。Tomcat是一个免费的、开源的Java Servlet容器,用于支持Java Servlet和JavaServer Pages(JSP)等网页技术。通过Tomcat,我们可以将程序部署到服务器上,并通过浏览器访问图书管理系统。 在图书管理程序中,模型(Model)负责数据的处理和存储,视图(View)负责展示数据给用户,控制器(Controller)负责处理用户的请求和操作,并协调模型和视图之间的交互。通过MVC的设计模式,我们可以实现程序的结构清晰,逻辑清楚,易于维护和扩展。 总结来说,图书管理程序基于MVC设计模式,使用IDEA作为开发工具,MySQL作为数据库管理系统,Tomcat作为应用服务器。通过这种设计和工具的选择,我们可以方便地开发、部署和运行图书管理系统,并提供优秀的用户体验。 ### 回答2: 图书管理程序是一个基于MVC(Model-View-Controller)设计模式开发的应用程序。MVC设计模式将应用程序分为三个组件,包括模型(Model),视图(View)和控制器(Controller)。模型负责处理数据逻辑,包括数据的获取、存储、处理和传递。视图负责用户界面的展示和数据的呈现。控制器负责接收用户的输入,并根据输入控制模型和视图的行为。 开发工具方面,我们选择了Idea作为开发环境,Mysql作为数据库,Tomcat作为应用程序的服务器。 在图书管理程序中,我们使用MVC设计模式来提高代码的可维护性和可扩展性。模型层负责处理与图书相关的数据逻辑,包括数据库的连接和操作、数据的增删改查等。视图层负责展示用户界面,包括图书查询、借阅、归还等功能。控制器层负责接收用户的操作,根据操作调用相应的模型和视图进行处理。 在开发过程中,我们使用Idea作为开发工具,提供了强大的代码编辑、调试和版本控制等功能,可以极大地提高开发效率。Mysql作为数据库管理系统,为我们提供了数据存储和检索的功能,可以方便地操作和管理图书数据。Tomcat作为应用程序的服务器,可以部署和运行我们的图书管理程序。 综上所述,图书管理程序基于MVC设计模式,开发工具为Idea、Mysql和Tomcat,通过合理的架构和工具选择,可以实现高效、可靠的图书管理功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值