数据库之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的管理脚本

相关推荐
一只自律的鸡几秒前
【MySQL】第八章 数据类型
数据库·mysql
计算机学姐12 分钟前
基于SpringBoot的校园跑腿系统【数据可视化统计+原创精品】
java·vue.js·spring boot·后端·mysql·信息可视化·echarts
算法小菜鸟成长心得17 分钟前
postgresql18 版本,使用navicate15版本出现不兼容问题
数据库
while(1){yan}10 小时前
Spring事务
java·数据库·spring boot·后端·java-ee·mybatis
盛世宏博北京10 小时前
高效环境管控:楼宇机房以太网温湿度精准监测系统方案
开发语言·数据库·php·以太网温湿度变送器
运维行者_11 小时前
2026 技术升级,OpManager 新增 AI 网络拓扑与带宽预测功能
运维·网络·数据库·人工智能·安全·web安全·自动化
gfdhy11 小时前
【C++实战】多态版商品库存管理系统:从设计到实现,吃透面向对象核心
开发语言·数据库·c++·microsoft·毕业设计·毕设
Elastic 中国社区官方博客11 小时前
Elasticsearch:上下文工程 vs. 提示词工程
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
小唐同学爱学习11 小时前
如何解决海量数据存储
java·数据库·spring boot·mysql
wWYy.11 小时前
详解redis(15):缓存雪崩
数据库·redis·缓存