数据库之MHA

数据库之MHA

什么是MHA?

masterhight availabulity:基于主库的高可用环境下:主从复制 故障切换

主从的架构

MHA:最少要一主两从

mysql的单点故障问题,一旦主库崩溃,MHA可以在0-30秒内自动完成故障切换

MHA使用的是半同步复制,只要有一台从服务器写入数据,就会自动提交给客户端

如果master崩溃,slave就会从主的二进制日志保存文件

slave识别最新更新的日志

差异部分同步到slave

提升一个新的slave作为master

其他的slave继续和新的master同步

实验准备:

1、MHA架构搭建

2、模拟故障

3、故障恢复

MHA manager 192.168.233.30

master 192.168.233.110

slave1 192.168.233.120

slave2 192.168.233.130

node组件-------->需要部署在所有服务器上。manager组件依赖node组件,node组件监控mysql的状态

node组件靠ssh来进行通信

主从复制

set global read_only=1;

设置数据库为只读模式

所有的服务器都要按照MHA的依赖环境必须要按照epel源

先安装node组件,在安装MHA

masterha_check_ssh:检查MHA的SSH的配置状况

masterha_check_repl:检查mysql的复制情况

masterha_manager:启动manager的脚本

masterha_check_status:检测MHA的运行状态

masterha_master-monitor:检测master主机的情况,masters是否宕机

masterha_master_switch: 控制故障转移

masterha_conf_host: 添加或者删除配置的server信息。

masterha_stop:停止MHA脚本

node组件

save_binary_logs:保存和复制mater的二进制日志

apply_didd_relay_logs:识别二进制日志当中的差异事件,然后发送给其他的slave

filter_mysqlbinlog:去除不必要的回滚(mha已经不用了)

purge_relay_logs:同步之后清楚中继日志(不会阻塞sql的线程)

node依赖ssh通信,每台主机实现ssh的免密登录

master_ip_failover:自动切换时管理vip的脚本

master_ip_online_change:在切换时,vip的管理脚本

相关推荐
一水鉴天10 小时前
整体设计 定稿 之1 devOps 中台的 结论性表述(豆包助手)
服务器·数据库·人工智能
vx_dmxq21110 小时前
【微信小程序学习交流平台】(免费领源码+演示录像)|可做计算机毕设Java、Python、PHP、小程序APP、C#、爬虫大数据、单片机、文案
java·spring boot·python·mysql·微信小程序·小程序·idea
q***071410 小时前
Spring Boot 中使用 @Transactional 注解配置事务管理
数据库·spring boot·sql
m***923811 小时前
【SQL】MySQL中的字符串处理函数:concat 函数拼接字符串,COALESCE函数处理NULL字符串
数据库·sql·mysql
!停11 小时前
VS实用调试技巧
数据库
TracyCoder12311 小时前
MySQL 实战宝典(八):Java后端MySQL分库分表工具解析与选型秘籍
java·开发语言·mysql
8***235511 小时前
在Django中安装、配置、使用CKEditor5,并将CKEditor5录入的文章展现出来,实现一个简单博客网站的功能
数据库·django·sqlite
Token_w13 小时前
openGauss:全密态数据库的金融级安全实践
数据库·安全·金融
合作小小程序员小小店13 小时前
图书管理系统,基于winform+sql sever,开发语言c#,数据库mysql
开发语言·数据库·sql·microsoft·c#
ss27313 小时前
020:共享锁深度解析:从AQS原理到高并发实践
数据库·redis·缓存