MySQL8.0实现MHA高可用

一、简介

MHA(Master HA)是一款开源的 MySQL 的高可用程序,它为 MySQL 主从复制架构提供了 automating master failover 功能。MHA 在监控到 master 节点故障时,会提升其中拥有最新数据的 slave 节点成为新的master 节点,在此期间,MHA 会通过于其它从节点获取额外信息来避免一致性方面的问题。MHA 还提供了 master 节点的在线切换功能,即按需切换 master/slave 节点。

   MHA 服务有两种角色, MHA Manager(管理节点)和 MHA Node(数据节点): MHA Manager:   通常单独部署在一台独立机器上管理多个 master/slave 集群(组),每个 master/slave 集群称作一个 application,用来管理统筹整个集群。 MHA node:   运行在每台 MySQL 服务器上(master/slave/manager),它通过监控具备解析和清理 logs 功能的脚本来加快故障转移。

 由上图我们可以看出,每个复制组内部和 Manager 之间都需要ssh实现无密码互连,只有这样,在 Master 出故障时, Manager 才能顺利的连接进去,实现主从切换功能

 二、工作原理

(1) 从宕机崩溃的 master 保存二进制日志事件(binlog events);

(2) 识别含有最新更新的 slave ;

(3) 应用差异的中继日志(relay log) 到其他 slave ;

(4) 应用从 master 保存的二进制日志事件(binlog events);

(5) 提升一个 slave 为新 master ;

(6) 使用其他的 slave 连接新的 master 进行复制。

三、MHA实现 

3.1环境准备

3.1.1准备四台虚拟机(均为centos 7.x )

3.1.2 更换yum源

3.1.3关闭防火墙,禁用SELinux

3.1.4 host配置 

在不同的机器上配置名字和IP地址 

机器名称 IP配置 服务角色 备注
manager 172.16.90.211 manager控制器 用于监控管理
master 172.16.90.212 数据库主服务器 开启bin-log relay-log 关闭relay_log
slave1 172.16.90.213 数据库从服务器 开启bin-log relay-log 关闭relay_log
slave2 172.16.90.214 数据库从服务器 开启bin-log relay-log 关闭relay_log

 根据上表     名字要在不同的机器上分别输入如下命令

hostnamectl set-hostname manager
                         master
                         salve1
                         salve2

IP地址在其中一台输入即可 

[root@node4 ~]# cat >> /etc/hosts << EOF
> 172.16.90.111 manager
> 172.16.90.112 master
> 172.16.90.113 slave1
> 172.16.90.114 slave2
> EOF

3.2初始主节点 master 的配置

【master】 

 3.2.1解压·

  将mysql-8.0.18-1.el7.x86_64.rpm-bundle.tar包下载后复制到master虚拟机,再从这个虚拟机拷贝到slave1和slave2虚拟机的~目录

scp mysql-8.0.18-1.el7.x86_64.rpm-bundle.tar slave1:~

安装途中四个包,安装时可能会发现缺少依赖, 

 安装后我这里显示有个包需要移除

[rootnode2 MySQL]# yum remove mariadb-libs
3.2.2配置 master 文件

修改 master 的数据库配置文件来对其进行初始化配置

 在如图所示的地方插入两段话

vim /etc/my.cnf 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值