基于MHA+semi sync实现mysql数据库的高可用

发布时间:2020-08-03 08:59:08 作者:水柔山
来源:网络 阅读:2624

一、实验原理:

1、拓扑结构图如下:

基于MHA+semi sync实现mysql数据库的高可用

2、工作原理:

3、工具包:

MHA软件由两部分组成,Manager工具包和Node工具包

1、 Manager工具包主要包括以下几个工具:

2、Node工具包:这些工具通常由MHA Manager的脚本触发,无需人为操作)主要包括以下几个工具:

二、实验环境准备:

1、vmware中准备四台虚拟主机

主机名分别为manager,master,slave1,slave2 系统为centos7

对应ip:192.168.190.128-131

2、setenforce 0 关掉selinux

iptables -F 清掉防火墙

3、配置好yum源,以及epel源

4、四台虚拟主机保证时间同步,ntpdate命令

三、实验步骤:

1、四台主机实现ssh无密连接

ssh-keygen 任意一台主机生成公钥私钥对

ssh-copy-id 192.168.190.128 生成文件在.ssh目录

scp -r /root/.ssh 192.168.190.129

scp -r /root/.ssh 192.168.190.130

scp -r /root/.ssh 192.168.190.131

2、manager节点

(1) yum install mha4mysql-manager-0.56-0.el6.noarch.rpm mha4mysql-node-0.56-0.el6.noarch.rpm

(2) mkdir /data/mastermha/app1/ -pv

(3)vim /etc/mastermha/app1.cnf

[server default]
user=mhauser 主服务器的管理账号
password=centos mhauser的密码
manager_workdir=/data/mastermha/app1/ 工作目录
manager_log=/data/mastermha/app1/manager.log 日志目录
remote_workdir=/data/mastermha/app1/
ssh_user=root ssh连接账号
repl_user=repluser 复制账号
repl_password=centos 复制账号的密码
ping_interval=1
[server1]
hostname=192.168.190.129 主服务器
candidate_master=1 有机会晋升为主
[server2]
hostname=192.168.190.130 从服务器
candidate_master=1 有机会晋升为主
[server3]
hostname=192.168.190.131 从服务器
candidate_master=1 有机会晋升为主

3、master,slave1,slave2节点

yum install mha4mysql-node-0.56-0.el6.noarch.rpm

4、master节点

(1)systemctl start mariadb

(2)vim /etc/my.cnf

log-bin 启用二级制
server_id=1 服务器id,每个节点必须不同
innodb_file_per_table 每个库,每张表
skip_name_resolve=1 通过ip连接,不解析主机名
log_slave_updates = 1 主从切换时用
plugin_load = "rpl_semi_sync_master=semisync_master.so;rpl_semi_sync_slave=semisync_slave.so" 加载半同步复制的插件,主从的都装,主坏,从顶上时实现半同步
loose_rpl_semi_sync_master_enabled = 1 开启主的半同步功能
loose_rpl_semi_sync_slave_enabled = 1 开启从的半同步功能
loose_rpl_semi_sync_master_timeout = 5000

            mysql
            mysql>show master logs
            mysql>grant replication slave on *.* to repluser@'192.168.31.%' identified by ‘centos';
            mysql>grant all on *.* to mhauser@‘192.168.190.%’ identified by ‘magedu‘;
            show variables like '%semi%';

5、slave1节点和slave2节点

vim /etc/my.cnf

[mysqld]
server_id=2 不同节点此值各不相同
log-bin
read_only 只读,对超级用户无效,主坏切换为主时,全局变量会变
relay_log_purge=0 不删除中继日志
skip_name_resolve=1 不解析主机名,通过ip连接
plugin_load = "rpl_semi_sync_master=semisync_master.so;rpl_semi_sync_slave=semisync_slave.so" 加载半同步复制的插件,主从的都装,主坏,从顶上时实现半同步
loose_rpl_semi_sync_master_enabled = 1 开启主的半同步功能
loose_rpl_semi_sync_slave_enabled = 1 开启从的半同步功能
loose_rpl_semi_sync_master_timeout = 5000

        mysql>CHANGE MASTER TO MASTER_HOST=‘MASTER_IP', MASTER_USER='repluser', MASTER_PASSWORD=‘centos', MASTER_LOG_FILE='mariadb-bin.000001', MASTER_LOG_POS=245;

6、 manager节点上进行测试

1、masterha_check_ssh --conf=/etc/mastermha/app1.cnf 检测ssh连通性

2、masterha_check_repl --conf=/etc/mastermha/app1.cnf 检测复制功能

基于MHA+semi sync实现mysql数据库的高可用

3、masterha_manager --conf=/etc/mastermha/app1.cnf 启动mha管理

4、停掉主节点的mariadb服务,查看对应的日志

基于MHA+semi sync实现mysql数据库的高可用

发现原来主节点已经转移了

对于坏的故障主节点可以重新设置为集群里面的从节点,需要再次修改manager的配置文件

注意:第一次主从切换时,/data/mastermha/app1/会生成app1.failover.complete空文件,下次再次切换的时候如果发现该目录下存在该文件将不允许触发切换,若再次切换,将其删除。mha的管理工具,一次性在前台执行,发生故障后,需手动再次开启。

推荐阅读:
  1. 详解java实现HTTP请求的三种方式
  2. 【java 多线程】守护线程与非守护线程的详解

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mha 半同步 复制实现

上一篇:js如何实现3D旋转相册

下一篇:clickhouse linux安装

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》