MySQL+MHA高可用服务集群搭建

本文详细介绍了如何搭建MySQL一主两从的高可用环境,并结合MHA(Master High Availability)实现故障自动切换。内容包括MHA的概念、组成及特点,MySQL的主从配置、权限授权、无密码认证设置,以及MHA的安装、配置和测试。此外,还模拟了故障场景,展示了故障发生后的修复步骤和监控日志分析。
摘要由CSDN通过智能技术生成

文章目录

一、MHA概念

(1)MHA(MasterHigh Availability)是一套优秀的MySQL高可用环境下故障切换和主从复制的软件。

(2)MHA 的出现就是解决MySQL 单点的问题。

(3)MySQL故障切换过程中,MHA能做到0-30秒内自动完成故障切换操作。

(4)MHA能在故障切换的过程中最大程度上保证数据的一致性,以达到真正意义上的高可用。

1、MHA 的组成

(1)MHA Node(数据节点)

MHA Node 运行在每台 MySQL 服务器上。

(2)MHA Manager(管理节点)

MHA Manager 可以单独部署在一台独立的机器上,管理多个 master-slave 集群;也可以部署在一台 slave 节点上。

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

2、MHA 的特点

(1)自动故障切换过程中,MHA试图从宕机的主服务器上保存二进制日志,最大程度的保证数据不丢失。

(2)使用半同步复制,可以大大降低数据丢失的风险,如果只有一个slave已经收到了最新的二进制日志,MHA可以将最新的二进制日志应用于其他所有的slave服务器上,因此可以保证所有节点的数据一致性。

(3)目前MHA支持一主多从架构,最少三台服务,即一主两从。

二、搭建MySQL+MHA

主机 操作系统 IP地址 安装包 / 软件 / 工具
MHAmanager CentOS7-3 192.168.10.11 MHAnode组件、MHAmanager组件
master CentOS7-3 192.168.10.12 mysql-boost-5.7.20.tar.gz、MHAnode组件
Slave1 CentOS7-3 192.168.10.13 mysql-boost-5.7.20.tar.gz、MHAnode组件
Slave2 CentOS7-3 192.168.10.14 mysql-boost-5.7.20.tar.gz、MHAnode组件
检测三台mysql服务器服务是否启动
netstat -natp | grep 3306

1、所有服务器,关闭系统防火墙和安全机制

systemctl stop firewalld
systemctl disable firewalld
setenforce 0

2、修改 master(192.168.10.12)、Slave1(192.168.10.13)、Slave2(192.168.10.14) 节点的主机名

hostnamectl set-hostname master
su -

hostnamectl set-hostname slave1
su -

hostnamectl set-hostname slave2
su -

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3、修改三台MySQL服务器的主配置文件/etc/my.cnf

master:master(192.168.10.12)

vim /etc/my.cnf
[mysqld]
server-id = 1
log_bin = master-bin
log-slave-updates = true

systemctl restart mysqld

ln -s /usr/local/mysql/bin/mysql /usr/sbin/
ln -s /usr/local/mysql/bin/mysqlbinlog /usr/sbin/

在这里插入图片描述

在这里插入图片描述

slave:slave1(192.168.10.13)、slave2(192.168.10.14)

vim /etc/my.cnf
server-id = 2  
#server-id = 3  slave2则为3,三台服务器 server-id 不能一样
log_bin = master-bin
relay-log = relay-log-bin
relay-log-index = slave-relay-bin.index

systemctl restart mysqld

ln -s /usr/local/mysql/bin/mysql /usr/sbin/
ln -s /usr/local/mysql/bin/mysqlbinlog /usr/sbin/

在这里插入图片描述
在这里插入图片描述

4、配置MySQL一主两从

MySQL服务器进行MySQL授权

mysql -uroot -pqwe123

grant replication slave on *.* to 'myslave'@'192.168.10.%' identified by 'qwe123';
grant all privileges on *.* to 'mha'@'192.168.10.%' identified by 'manager';
grant all privileges on *.* to 'mha'@'master' identified by 'manager';
grant all privileges on *.* to 'mha'@'slave1' identified by 'manager';
grant all privileges on *.* to 'mha'@'slave2' identified by 'manager';

在这里插入图片描述

Slave1、Slave2 节点执行同步操作

在Master节点查看二进制文件和同步点
show master status;
在 Slave1、Slave2 节点执行同步操作
change master to master_host='192.168.10.12',master_user='myslave',master_password='qwe123',master_log_file='master-bin.000001',master_log_pos=1893;

start slave;
show slave status\G

在这里插入图片描述
在这里插入图片描述

Slave1、Slave2 节点设置为只读模式

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值