我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

一、实验原理:

1、拓扑结构图如下:

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

2、工作原理:

  • 从宕机崩溃的master保存二进制日志事件(binlog events)

  • 识别含有最新更新的slave

  • 应用差异的中继日志(relay log)到其他的slave

  • 应用从master保存的二进制日志事件(binlog events)

  • 提升一个slave为新的master

  • 使其他的slave连接新的master进行复制

3、工具包:

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

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

  • 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信息

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

  • save_binary_logs 保存和复制master的二进制日志
  • apply_diff_relay_logs 识别差异的中继日志事件并将其差异的事件应用于其他的slave
  • filter_mysqlbinlog 去除不必要的ROLLBACK事件(MHA已不再使用此工具)purge_relay_logs 清除中继日志(不会阻塞SQL线程)

二、实验环境准备:

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的管理工具,一次性在前台执行,发生故障后,需手动再次开启。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何在MySQL数据库中实现MHA高可用配置

本篇文章给大家分享的是有关如何在MySQL数据库中实现MHA高可用配置,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、MHA介绍(一)、什么是MHAMHA(MasterHig
2023-06-06

基于keepalived配置数据库主从实现高可用

基于keepalived配置数据库主从实现高可用使用keepalived来监听端口,实现数据库的高可用。实现效果,其中一台数据库服务器突然出故障或关机时,应该不影响应用正常运行,等待服务器启动之后,数据能够自动同步,保持数据一致性。主从配置架构图及原理主从状态
基于keepalived配置数据库主从实现高可用
2021-08-06

如何在MySQL中实现数据库复制和高可用性

要在MySQL中实现数据库复制和高可用性,可以采用以下方法:MySQL复制:MySQL提供了内置的复制功能,可以使用主从复制或主主复制来实现数据库复制。主从复制是将数据从一个MySQL服务器(主服务器)复制到另一个MySQL服务器(从服务器
如何在MySQL中实现数据库复制和高可用性
2024-03-06

Galera集群实现MySQL数据高可用性的秘密

Galera集群通过其独特的设计和实现方式,确保了MySQL数据库的高可用性。以下是Galera集群实现MySQL数据高可用性的关键技术和特性:多主复制:Galera集群支持真正的多主复制,这意味着集群中的每个节点都可以接收写操作,从而消除
Galera集群实现MySQL数据高可用性的秘密
2024-09-04

阿里云数据库高可用方案实现稳定可靠的数据管理

随着云计算和大数据时代的到来,数据库成为企业存储和处理海量数据的重要工具。然而,数据库的高可用性一直是企业关注的重点,因为数据库宕机可能导致业务中断、数据丢失等问题。阿里云数据库高可用方案提供了一种稳定可靠的解决方案,帮助企业实现数据库的高可用性。详细说明:1.主备架构阿里云数据库高可用方案的核心是主备架构,通过
阿里云数据库高可用方案实现稳定可靠的数据管理
2023-12-27

阿里云数据库代理服务——实现高可用性和高性能的数据库连接解决方案

阿里云数据库代理服务是一种用于实现数据库高可用性和高性能的解决方案。它通过在客户端和数据库之间建立一个代理服务器,将客户端请求转发到后端数据库,并处理请求并返回结果给客户端。本文将详细介绍阿里云数据库代理服务的功能、优势以及应用场景。详细说明:功能介绍阿里云数据库代理服务(DatabaseProxyService
阿里云数据库代理服务——实现高可用性和高性能的数据库连接解决方案
2024-01-17

队列的数据持久化和高可用性在PHP与MySQL中的实现方法

引言:随着互联网的快速发展,大量的数据产生和处理对系统的性能提出了更高的要求。在众多数据处理的策略中,队列是一种广泛应用的机制,可以在不同模块之间进行异步通信和任务处理。本文将重点介绍队列的数据持久化和高可用性在PHP与MySQL中的实现方
2023-10-21

编程热搜

目录