一、什么是MHA

二、数据同步方式
1.异步复制---主服务器只要完成客户端提交的事务就返回结果,并不关心是否同步到数据
2.同步复制---当主服务器完成更新,并且同步到所有从服务器才会返回成功结果
3.半同步复制---当主服务器完成更新,至少有一个从服务器接收到并完成更新,主服务器就返回成功
三、MHA组成
由Node(数据节点)和Manager(管理节点)组成
1.MHA Node(数据节点)
MHA Node运行在每台Mysql服务器上
2.MHA Manager(管理节点)
1.MHA Manager 可以单独部署在一台独立的机器上,管理多个master-slave集群,也可以部署在一台slave节点上。
2.MHA Manager 会定时探测集群中的master节点,当master出现故障时,它可以自动将最新数据的slave 提升为新的master,然后将所有其他的slave重新指向新的master,整个故障转移过程对应用程序完全透明。
四、MHA特点
1.自动故障切换过程中, MHA试图从宕机的主服务器上保存二进制日志,最大程度的保证数据不丢失。
2.使用半同步复制 ,可以大大降低数据丢失的风险,如果只有一个slave已经收到了最新的二进制日志,MHA可以将最新的二进制日志应用于其它所有的slave服务器上,因此可以保证所有节点的数据一致性。
3.目前MHA支持一主多从架构,最少三台服务,即一主两从。
五、MHA工作原理
1、从宕机崩溃的master 保存二进制日志事件(binlog events);
2、识别含有最新的更新 slave 日志
3、应用差异的中继日志(relay log)到其他的slave
4、应用从master保存的二进制日志事件
5、提升一个 salve 为新的master
6、使其他的slave连接行的master 进行复制。
六、MHA部署

























本文详细介绍了MHA(MasterHighAvailability)在MySQL中的应用,包括数据同步的不同方式、MHA的组成(Node和Manager)、特点如自动故障切换和数据一致性保障,以及其工作原理。
8097

被折叠的 条评论
为什么被折叠?



