MYSQL实现高可用MHA

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介:

一、准备实验MYSQL Replication 环境:

MHA MYSQL 复制环境有特殊要求,例如各节点都要开启二进制日志及中继日志,各从节点必须显示启用其read-only 属性,并关闭relay_log_purge 功能等,这里对配置做事先说明。

本实验环境共有四个节点,其角色分配如下:

centos7.3:MariaDB master

centos7.4: MariaDB slave

centos7.5:MariaDB slave

centos7.6: MHA Manager


 二 、实验配置

、初始主节点centos7.3 配置:

[mysqld]

server-id = 1

log-bin = master-log

relay-log = relay-log

skip_name_resolve = ON

、所有centos7.5和7.4 节点依赖的配置:

[mysqld]

server-id = 2 # 复制集群中的各节点的id 均必须唯一;

relay-log = relay-log

log-bin = master-log

read_only = ON

relay_log_purge = 0 # 是否自动清空不再需要中继日志

skip_name_resolve = ON

 

、按上述要求分别配置好主从节点之后,按MYSQL 复制配置架构的配置方式将其配置完成并启动master 节点和各slave 节点,以及为各slave 节点启动其IO SQL 线程,确保主从复制运行无误。操作如下:

master 节点上:

MariaDB [(none)]>grant replication slave on *.* to 'slave@172.17.%.%' identified by 'magedu';

MariaDB [(none)]> flush privileges;

MariaDB [(none)]>show master status; 

slave 节点上:

[root@node3 ~]# mysql

MariaDB [(none)]>change master to master_host= 172.16.252.18;master_user= repluser ,master_password= replpass ,master_log_file= master-log.000003master_log_pos=498;

MariaDB [(none)]> start slave;

MariaDB [(none)]> show slave status\G;

三、 安装配置MHA

、在所有MYSQL 节点授权拥有管理权限的用户可在本地网络中有其他节点上远程访问。当然,此时仅需要且只能在master 节点运行类似如下SQL 语句即可。

mysql> GRANT ALL ON *.* TO 'mhaadmin'@'172.17.%.%' IDENTIFIED BY'mhapass';

、准备基于SSH 互信通信环境:

MHA 集群中的各节点彼此之间均需要基于ssh 互信通信,以实现远程控制及数据管理功能。简单起见,可在Manager 节点生成密钥对儿,并设置其可远程连接本地主机后,将私钥文件及authorized_keys 文件复制给余下的所有节点即可。

下面操作在node4 Manager 节点上操作:

[root@node4 ~]# ssh-keygen -t rsa

[root@node4 ~]#ssh-copy-id -i .ssh/id_rsa.pub root@ip

注意:主从数据库相互之间要实现无密码登录,MHA manager 要能登录另外三台就可以了。

 进行MHA 安装包安装

Manager 节点: yum install mha4mysql-manager-0.56-0.el6.noarch.rpm

所有节点,包括Manager: #yum install mha4mysql-node-0.56-0.el6.norch.rpm

、初始化MHA ,进行配置

Manager 节点需要为每个监控的master/slave 集群提供一个专用的配置文件,而所有的master/slave 集群也可共享全局配置。全局配置文件默认为/etc/masterha_default.cnf ,其为可选配置。如果仅监控一组master/slave 集群,也可直接通过application 的配置来提供各服务器的默认配置信息。而每个application 的配置文件路径为自定义。

 定义MHA 管理配置文件

MHA 专门创建一个管理用户,方便以后使用,在mysql 的主节点上,三个节点自动同步

mkdir /etc/mha_master

vim /etc/mha_master/app1.cnf

配置文件内容如下;

[server default] // 适用于server1,2,3 server 的配置

user=mhaadmin //mha 管理用户

password=mhapass //mha 管理密码

manager_workdir=/etc/mha_master/app1 //mha_master 自己的工作路径

manager_log=/etc/mha_master/manager.log // mha_master 自己的日志文件

remote_workdir=/mydata/mha_master/app1 // 每个远程主机的工作目录在何处

ssh_user=root // 基于ssh 的密钥认证

repl_user=slave// 数据库用户名

repl_password=magedu // 数据库密码

ping_interval=1 // ping 间隔时长

[server1] // 节点1

hostname=172.16.5.102 // 节点主机地址

ssh_port=22 // 节点ssh 端口

candidate_master=1 // 将来可不可以成为master 候选节点主节点

[server2]

hostname=172.16.5.173

ssh_port=22

candidate_master=1

[server3]

hostname=172.16.5.174

ssh_port=22

candidate_master=1

 检测各节点间ssh 互信通信配置是否Ok:

[root@node4 ~]# masterha_check_ssh -conf=/etc/mha_master/app1.cnf

输出信息最后一行类似如下信息,表示其通过检测。

[info]All SSH connection tests passed successfully.

检查管理的MySQL 复制集群的连接配置参数是否OK 

[root@node4 ~]#masterha_check_repl -conf=/etc/mha_master/app1.cnf

如果测试时会报错 ,可能是从节点上没有账号,因为这个架构,任何一个从节点,将有可能成为主节点,所以也需要创建账号。

因此,这里只要在mater 节点上再次执行以下操作即可:

MariaDB [(none)]>GRANT REPLICATION SLAVE,REPLICATION CLIENT ON *.* TO 'slave@172.17.%.%' IDENTIFIED BY 'magedu';

MariaDB [(none)]> FLUSH PRIVILEGES;

Manager 节点上再次运行,就显示Ok 了。

四、启动MHA

[root@node4 ~]#nohup masterha_manager -conf=/etc/mha_master/app1.cnf &> /etc/mha_master/manager.log &

启动成功后,可用过如下命令来查看master 节点的状态:

masterha_check_status -conf=/etc/mha_master/app1.cnf

app1 (pid:4978)is running(0:PING_OK),master:172.16.252.18

上面的信息中“app1 (pid:4978)is running(0:PING_OK) 表示MHA 服务运行OK ,否则,则会显示为类似“app1 is stopped(1:NOT_RUNNINg).

如果要停止MHA ,需要使用master_stop 命令。

masterha_stop -conf=/etc/mha_master/app1.cnf

五、测试MHA 测试故障转移

(1) master 节点关闭mariadb 服务模拟主节点数据崩溃

killall -9 mysqld mysqld_safe

rm -rf /var/lib/mysql/*

(2) manager 节点查看日志:

/data/masterha/app1/manager.log 日志文件中出现如下信息,表示manager 检测到172.16.252.18 节点故障,而后自动执行故障转移,将172.16.252.17 提升为主节点。注意,故障转移完成后,manager 将会自动停止,此时使用masterha_check_status 命令检测将会遇到错误提示,如下所示:

masterha_check_status –conf=/etc/masterha/app1.cnf

app1 is stopped(2:NOT_RINNING).

六、测试MHA 测试故障转移

(3) 提供新的从节点以修复复制集群

原有 master 节点故障后,需要重新准备好一个新的 MySQL 节点。基于来自于master 节点的备份恢复数据后,将其配置为新的 master 的从节点即可。注意,新加入的节点如果为新 增节点,其IP地址要配置为原来 master 节点的IP ,否则,还需要修改 app1.cnf 中相应的 ip 地址。随后再次启动 manager ,并再次检测其状态。

(4) 新节点提供后再次执行检查操作

masterha_check_status -conf=/etc/mha_master/app1.cnf

masterha_check_repl -conf=/etc/mha_master/app1.cnf

检查无误,再次运行,这次要记录日志

masterha_manager -conf=/etc/mha_master/app1.cnf >/etc/mha_master/manager.log 2>&1

七、 新节点上线,故障转换恢复注意事项

(1) 、在生产环境中,当你的主节点挂了后,一定要在从节点上做一个备份,拿着备份文件把主节点手动提升为从节点,并指明从哪一个日志文件的位置开始复制。

(2) 、每一次自动完成转换后,每一次的(replication health ) 检测不ok 始终都是启动不了必须手动修复主节点,除非你改配置文件

(3) 、手动修复主节点提升为从节点后,再次运行检测命令

 masterha_check_repl --conf=/etc/mha_master/app1.cnf

app1 (pid:3211) is running(0:PING_OK), master:172.16.5.103

(4) 、再次运行起来就恢复成功了

masterha_manager --conf=/etc/mha_master/app1.cnf


本文转自    honeyorange   51CTO博客,原文链接:http://blog.51cto.com/13172732/2044512

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8月前
|
SQL 容灾 关系型数据库
rds容灾与高可用
rds容灾与高可用
129 4
|
8月前
|
存储 关系型数据库 MySQL
Mysql高可用|索引|事务 | 调优
Mysql高可用|索引|事务 | 调优
|
2月前
|
存储 SQL 关系型数据库
Mysql高可用架构方案
本文阐述了Mysql高可用架构方案,介绍了 主从模式,MHA模式,MMM模式,MGR模式 方案的实现方式,没有哪个方案是完美的,开发人员在选择何种方案应用到项目中也没有标准答案,合适的才是最好的。
249 3
Mysql高可用架构方案
|
5月前
|
运维 容灾 关系型数据库
MySQL高可用方案--Xenon全解
MySQL高可用方案--Xenon全解
|
7月前
|
运维 容灾 关系型数据库
介绍几种 MySQL 官方高可用方案
MySQL 官方提供了多种高可用部署方案,从最基础的主从复制到组复制再到 InnoDB Cluster 等等。本篇文章以 MySQL 8.0 版本为准,介绍下不同高可用方案架构原理及使用场景。
1555 3
介绍几种 MySQL 官方高可用方案
|
5月前
|
SQL 关系型数据库 MySQL
orchestrator搭建mysql高可用
orchestrator搭建mysql高可用
68 0
|
5月前
|
缓存 关系型数据库 MySQL
如何实现mysql高可用集群
如何实现mysql高可用集群
70 0
|
5月前
|
安全 关系型数据库 MySQL
【MySQL】Orchestrator最简单的 mysql 高可用方案最细细细细~
【MySQL】Orchestrator最简单的 mysql 高可用方案最细细细细~
|
5月前
|
缓存 关系型数据库 MySQL
MySQL调优秘籍曝光!从索引到事务,全方位解锁高可用秘诀,让你的数据库性能飞起来!
【8月更文挑战第6天】MySQL是顶级关系型数据库之一,其性能直接影响应用的高可用性与用户体验。本文聚焦MySQL的高性能调优,从索引设计到事务管理,逐一解析。介绍如何构建高效索引,如联合索引`CREATE INDEX idx_order_customer ON orders(order_id, customer_id);`,以及索引覆盖查询等技术。
89 0
|
7月前
|
SQL 关系型数据库 MySQL
MySQL高可用架构设计:从主从复制到分布式集群
MySQL高可用性涉及主从复制、半同步复制和Group/InnoDB Cluster。主从复制通过二进制日志同步数据,保证故障时可切换。半同步复制确保事务在至少一个从服务器确认后才提交。Group Replication是多主复制,支持自动故障切换。InnoDB Cluster是8.0的集成解决方案,简化集群管理。使用这些技术能提升数据库的稳定性和可靠性。
610 2