MySQL-MHA高可用集群部署(二)(MySQL MHA High Availability Cluster Deployment Part II )

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。

本人主要分享计算机核心技术:系统维护、数据库、网络安全、自动化运维、容器技术、云计算、人工智能、运维开发、算法结构、物联网、JAVA 、Python、PHP、C、C++等。
不同类型针对性训练,提升逻辑思维,剑指大厂,非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。

** 记得之前发过一篇文章,名字叫《MySQL------MHA高可用集群部署及故障切换》,之后有很多小伙伴在评论区问我,何时有相关的深入配置管理文章出来,因此,我对前面的各类架构逐一进行整理,然后发布出来。那么今天来发布的MHA的架构整体规划与配置操作。**

**一.简介

MHA(Master High Availability)目前在MySQL高可用方面是一个相对成熟的解决方案,作为MySQL高可用性环境下故障切换和主从提升的高可用软件。在MySQL故障切换过程中,MHA能做到在0~30秒之内自动完成数据库的故障切换操作,并且在进行故障切换的过程中,MHA能在最大程度上保证数据的一致性,以达到真正意义上的高可用。
MHA由两部分组成:MHA Manager(管理节点)和MHA Node(数据节点)。MHA Manager可以单独部署在一台独立的机器上管理多个master-slave集群,也可以部署在一台slave节点上。MHA Node运行在每台MySQL服务器上,MHA Manager会定时探测集群中的master节点,当master出现故障时,它可以自动将最新数据的slave提升为新的master,然后将所有其他的slave重新指向新的master。整个故障转移过程对应用程序完全透明。
目前MHA主要支持一主多从的架构,要搭建MHA,要求一个复制集群中必须最少有三台数据库服务器,一主二从,即一台充当master,一台充当备用master,另外一台充当从库,因为至少需要三台服务器**

**二.布署规划

系统信息**

bash 复制代码
[root@db250 ~]# cat /etc/redhat-release
CentOS release 6.8 (Final)
[root@db250 ~]# uname -r
2.6.32-642.el6.x86_64

数据库
mysql57-community-release-el6-9.noarch.rpm
环境规划

|-----------|-------------|-------------------|
| 名称 | 节点 | 节点IP |
| Db251 | 集群管理节点 | 192.168.4.250 |
| Db252 | 主库 | 192.168.4.251 |
| Db253 | 从库(备主库) | 192.168.4.253 |
| Db254 | 从库 | 192.168.4.254 |

架构图如下

配置SSH免密登陆与hosts文件
配置hosts文件

bash 复制代码
cat>>/etc/hosts<<EOF
192.168.4.250 db250
192.168.4.251 db251
192.168.4.253 db253
192.168.4.254 db254
EOF

配置完成后检查下

bash 复制代码
[root@db254 ~]# tail -4 /etc/hosts
192.168.4.250 db250
192.168.4.251 db251
192.168.4.253 db253
192.168.4.254 db254

配置SSH免密钥登陆

bash 复制代码
ssh-keygen -t rsa
ssh-copy-id 192.168.4.251
ssh-copy-id 192.168.4.253
ssh-copy-id 192.168.4.254

Mysql
--------------以上配置所有服务器都需要配置----------------

**安装mysql与配置主从同步

安装mysql数据库服务**

bash 复制代码
rpm -ivh mysql57-community-release-el6-9.noarch.rpm
yum install mysql-community-server -y
/etc/init.d/mysqld start

默认密码是在

bash 复制代码
[root@db254 ~]# grep 'temporary password' /var/log/mysqld.log
2017-08-30T08:08:05.956867Z 1 [Note] A temporary password is generated for root@localhost: f;2YK51qXlo/

  

修改下默认密码吧,为了后面方便操作

sql 复制代码
mysql> alter user 'root'@'localhost' identified by '123456';

--------------以上配置三台数据库服务器都需要配置----------------

**配置主从同步

Db251与db253的配置文件都需要配置开启binlog**

bash 复制代码
server_id=251
log_bin=master-bin
log_bin_index=master-bin.index

server_id=253
log_bin=slave-bin
log_bin_index=slave-bin.index
log-slave-updates
relay_log_index=slave-relay-bin.index
relay_log=slave-relay-bin

server_id=254
relay_log_index=slave-relay-bin.index
relay_log=slave-relay-bin

**同步主库数据到从库,主从同步操作请参考之前的文章

检查主从同步状态**

sql 复制代码
mysql -uroot -p123456 -e "show slave status\G" |egrep "Slave_IO_Running|Slave_SQL_Running"

所有数据库节点配置MHA管理用户与权限

sql 复制代码
grant all on . to mha@'192.168.4.%' identified by '123456';

至此所有基础环境组建完成

**安装配置MHA

https://downloads.mariadb.com/MHA/ 下载地址
整个MHA服务安装过程如下:**

安装依赖包

bash 复制代码
yum install perl-DBD-MySQL perl-Config-Tiny perl-Log-Dispatch -y 
yum install perl-Parallel-ForkManager perl-Time-HiRes --y

管理节点安装

bash 复制代码
rpm -ivh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
yum localinstall -y mha4mysql-manager-0.52-0.noarch.rpm
yum localinstall -y mha4mysql-node-0.52-0.noarch.rpm
其它节点安装
bash 复制代码
yum localinstall -y mha4mysql-node-0.52-0.noarch.rpm
安装过程中可能会报错,根据提示去解决
配置过程如下:
bash 复制代码
Mkdir /mha
[root@db250 ~]# vim /etc/masterha_default.cnf
[server default]
#刚才授权的mysql管理用戶名
user=mha
password=123456
manager_workdir=/mha
manager_log=/mha/manager.log
remote_workdir=/mha

#ssh免密钥登录的帐号名
ssh_user=root
#mysql复制帐号,用来在主从机之间同步二进制日志等
repl_user=slave
repl_password=123456

#ping间隔,用来检测master是否正常
ping_interval= 1

[server1]
hostname=db251
master_binlog_dir=/var/lib/mysql
#候选master挂掉时候优先让它顶
candidate_master=1

[server2]
hostname=db253
master_binlog_dir=/var/lib/mysql/
candidate_master=1

[server3]
hostname=db254
master_binlog_dir=/var/lib/mysql/
no_master=1
#不能成为master

masterha_check_ssh 检查MHA的SSH配置状况
masterha_check_repl 检查MySQL复制状况
masterha_manger 启动MHA
masterha_check_status 检测当前MHA运行状态
masterha_master_monitor 检测master是否宕机
masterha_master_switch 控制故障转移(自动或者手动)
masterha_conf_host 添加或删除配置的server信息
验证操作
bash 复制代码
[root@db250 ~]# masterha_check_ssh --conf=/etc/masterha_default.cnf
检查主从同步
masterha_check_repl --conf=/etc/masterha_default.cnf
启动MHA服务
bash 复制代码
[root@db250 ~]# masterha_manager --conf=/etc/masterha_default.cnf &
[1] 2035
[root@db250 ~]# Fri Sep  1 01:52:25 2017 - [info] Reading default configuratoins from /etc/masterha_default.cnf..
Fri Sep  1 01:52:25 2017 - [info] Reading application default configurations from /etc/masterha_default.cnf..
Fri Sep  1 01:52:25 2017 - [info] Reading server configurations from /etc/masterha_default.cnf..
查看启动日志


到此MHA高可用总算成功了,也算可以的哈!
接下来模拟下故障,将db251关闭
bash 复制代码
[root@db251 ~]# /etc/init.d/mysqld stop
Stopping mysqld:              [  OK  ]
查看日志


发现新的主库已切换到db253这台

服务器上了,接下来查看下主从同步的情况

当原来的主服务器故障修复后,需要手工将原主变成从

bash 复制代码
[root@db250 ~]# grep -i "All other slaves should start" /mha/manager.log
Fri Sep  1 01:59:05 2017 - [info]  All other slaves should start replication from here. Statement should be: CHANGE MASTER TO MASTER_HOST='db253 or 192.168.4.253', MASTER_PORT=3306, MASTER_LOG_FILE='slave-bin.000003', MASTER_LOG_POS=760546, MASTER_USER='slave', MASTER_PASSWORD='xxx';
因此此时我在原主库上执行操作将修复的主库改为从库


接下来在新的主库上写入数据来测试同步情况



相关推荐
m0_748235954 小时前
CentOS 7使用RPM安装MySQL
android·mysql·centos
leegong231114 小时前
PostgreSQL 初中级认证可以一起学吗?
数据库
秋野酱5 小时前
如何在 Spring Boot 中实现自定义属性
java·数据库·spring boot
weisian1516 小时前
Mysql--实战篇--@Transactional失效场景及避免策略(@Transactional实现原理,失效场景,内部调用问题等)
数据库·mysql
AI航海家(Ethan)6 小时前
PostgreSQL数据库的运行机制和架构体系
数据库·postgresql·架构
Kendra9198 小时前
数据库(MySQL)
数据库·mysql
时光书签9 小时前
Mongodb副本集群为什么选择3个节点不选择4个节点
数据库·mongodb·nosql
人才程序员11 小时前
【C++拓展】vs2022使用SQlite3
c语言·开发语言·数据库·c++·qt·ui·sqlite
极客先躯11 小时前
高级java每日一道面试题-2025年01月23日-数据库篇-主键与索引有什么区别 ?
java·数据库·java高级·高级面试题·选择合适的主键·谨慎创建索引·定期评估索引的有效性
指尖下的技术11 小时前
Mysql面试题----MyISAM和InnoDB的区别
数据库·mysql