MySQL的MHA

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

一、什么是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部署

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值