ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

2020-12-24

2020-12-24 15:57:22  阅读:135  来源: 互联网

标签:24 12 log MHA master ssh 2020 mha 节点


一、 简介

MHA(Master HA)是一款开源的 MySQL 的高可用程序,它为 MySQL 主从复制架构提供了 automating master failover 功能。MHA 在监控到 master 节点故障时,会提升其中拥有最新数据的 slave 节点成为新的master 节点,在此期间,MHA 会通过于其它从节点获取额外信息来避免一致性方面的问题。MHA 还提供了 master 节点的在线切换功能,即按需切换 master/slave 节点。
  MHA 是由日本人 yoshinorim(原就职于DeNA现就职于FaceBook)开发的比较成熟的 MySQL 高可用方案。MHA 能够在30秒内实现故障切换,并能在故障切换中,最大可能的保证数据一致性。目前淘宝也正在开发相似产品 TMHA, 目前已支持一主一从。

二、 MHA 服务

MHA 服务有两种角色, MHA Manager(管理节点)和 MHA Node(数据节点):
MHA Manager:
  通常单独部署在一台独立机器上管理多个 master/slave 集群(组),每个 master/slave 集群称作一个 application,用来管理统筹整个集群。
MHA node:
  运行在每台 MySQL 服务器上(master/slave/manager),它通过监控具备解析和清理 logs 功能的脚本来加快故障转移。
  主要是接收管理节点所发出指令的代理,代理需要运行在每一个 mysql 节点上。简单讲 node 就是用来收集从节点服务器上所生成的 bin-log 。对比打算提升为新的主节点之上的从节点的是否拥有并完成操作,如果没有发给新主节点在本地应用后提升为主节点。
在这里插入图片描述

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

三、

MHA工作原理总结为以下几条:
(1) 从宕机崩溃的 master 保存二进制日志事件(binlog events);
(2) 识别含有最新更新的 slave ;
(3) 应用差异的中继日志(relay log) 到其他 slave ;
(4) 应用从 master 保存的二进制日志事件(binlog events);
(5) 提升一个 slave 为新 master ;
(6) 使用其他的 slave 连接新的 master 进行复制。
在这里插入图片描述
为了方便我们后期的操作,我们在各节点的/etc/hosts文件配置内容中添加如下内容:
192.168.3.12 node1.keer.com node1
192.168.3.13 node2.keer.com node2
192.168.3.14 node3.keer.com node3
在这里插入图片描述

初始主节点 master 的配置

vim /etc/my.cnf
[mysqld]
character_set_server = utf8
log-bin=mysql-bin
server-id=1
relay_log=mysql-relay
skip_name_resolve
systemctl restart mariadb

在这里插入图片描述

所有 slave 节点依赖的配置

slave1

vim /etc/my.cnf
[mysqld]
server-id = 2 //复制集群中的各节点的id均必须唯一;
relay-log = relay-log //开启中继日志
log-bin = master-log //开启二进制日志

read_only = ON				//启用只读属性
relay_log_purge = 0			//是否自动清空不再需要中继日志
skip_name_resolve			//关闭名称解析(非必须)
log_slave_updates = 1       //使得更新的数据写进二进制日志中

systemctl restart mariadb

slave2

vim /etc/my.cnf
[mysqld]
server-id = 3 //复制集群中的各节点的id均必须唯一;
relay-log = relay-log //开启中继日志
log-bin = master-log //开启二进制日志

read_only = ON				//启用只读属性
relay_log_purge = 0			//是否自动清空不再需要中继日志
skip_name_resolve			//关闭名称解析(非必须)
log_slave_updates = 1       //使得更新的数据写进二进制日志中

systemctl restart mariadb
本步骤完成。

配置一主多从复制架构

主节点:
在这里插入图片描述

从节点1:
在这里插入图片描述

从节点2:
在这里插入图片描述

本步骤完成。

安装配置MHA

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

grant all on . to ‘mhaadmin’@‘192.168.%.%’ identified by ‘mhapass’;
本步骤完成。

准备 ssh 互通环境

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

(注意三个节点都要做一遍)

ssh-keygen -t rsa
ssh-copy-id -i .ssh/id_rsa.pub root@node1
ssh-copy-id -i .ssh/id_rsa.pub root@node2
ssh-copy-id -i .ssh/id_rsa.pub root@node3
在这里插入图片描述

当三台机器都进行了上述操作以后,我们可以在 manager 机器上看到如下文件:

cd .ssh/
ls
authorized_keys
cat authorized_keys
在这里插入图片描述

三台机器的公钥都已经在authorized_keys这个文件中了,接着,我们只需要把这个文件发送至另外三台机器,这四台机器就可以实现 ssh 无密码互通了:

scp authorized_keys root@node1:~/.ssh/
scp authorized_keys root@node2:~/.ssh/
scp authorized_keys root@node3:~/.ssh/

三台机器都要免密.

三台都要测试ssh免密
在这里插入图片描述

安装 MHA 包
三个节点都需安装:mha4mysql-node-0.56-0.el6.norch.rpm
Manager 节点另需要安装:mha4mysql-manager-0.56-0.el6.noarch.rpm

三台服务器都要下载安装:

yum -y install perl-DBD-MySQL epel-release
1
下载链接mha的rpm包
链接:https://pan.baidu.com/s/1tf49NWEEWlnKUpv3v_zssg
提取码:8wrt

在这里我建议用yum安装mha包

yum -y install mha4mysql-manager-0.56-0.el6.noarch.rpm mha4mysql-node-0.56-0.el6.norch.rpm
1
本步骤完成

初始化 MHA ,进行配置

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

[server default]
user=mhaadmin
password=mhapass
manager_workdir=/etc/mha_master/app1
manager_log=/etc/mha_master/manager.log
remote_workdir=/mydata/mha_master/app1
ssh_user=root
repl_user=slave
repl_password=123
ping_interval=1
[server1]
hostname=192.168.59.141
ssh_port=22
candidate_master=1
[server2]
hostname=192.168.59.142
ssh_port=22
candidate_master=1
[server3]
hostname=192.168.59.143
ssh_port=22
candidate_master=1
在这里插入图片描述
本步骤完成。

对三个节点进行检测

(1) 检测各节点间 ssh 互信通信配置是否 ok
我们在 Manager 机器上输入下述命令来检测:

masterha_check_ssh -conf=/etc/mha_master/mha.cnf
在这里插入图片描述

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

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

在这里插入图片描述
我们发现检测失败,这可能是因为从节点上没有账号,因为这个架构,任何一个从节点, 将有可能成为主节点, 所以也需要创建账号。
  因此,我们需要在master节点上再次执行以下操作:

grant replication slave,replication client on . to ‘slave’@‘192.168.%.%’ identified by ‘keer’;
flush privileges;
执行完这段操作之后,我们再次运行检测命令:
masterha_check_repl -conf=/etc/mha_master/mha.cnf
在这里插入图片描述

启动MHA

我们在 manager 节点上执行以下命令来启动 MHA:

nohup masterha_manager -conf=/etc/mha_master/mha.cnf &> /etc/mha_master/manager.log &

在这里插入图片描述

检查Manager状态:

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

在这里插入图片描述

测试MHA故障漂移

关闭master

systemctl stop mariadb

查看日志

tailf /etc/mha_master/manager.log
在这里插入图片描述
以上就是MHA

标签:24,12,log,MHA,master,ssh,2020,mha,节点
来源: https://blog.csdn.net/weixin_53309916/article/details/111635333

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有