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

相关推荐
Zfox_1 小时前
Redis:Hash数据类型
服务器·数据库·redis·缓存·微服务·哈希算法
陈丹阳(滁州学院)3 小时前
若依添加添加监听容器配置(删除键,键过期)
数据库·oracle
远方16094 小时前
14-Oracle 23ai Vector Search 向量索引和混合索引-实操
数据库·ai·oracle
GUIQU.5 小时前
【Oracle】数据仓库
数据库·oracle
恰薯条的屑海鸥6 小时前
零基础在实践中学习网络安全-皮卡丘靶场(第十六期-SSRF模块)
数据库·学习·安全·web安全·渗透测试·网络安全学习
咖啡啡不加糖6 小时前
Redis大key产生、排查与优化实践
java·数据库·redis·后端·缓存
曼汐 .6 小时前
数据库管理与高可用-MySQL高可用
数据库·mysql
MickeyCV6 小时前
使用Docker部署MySQL&Redis容器与常见命令
redis·mysql·docker·容器·wsl·镜像
2301_793102496 小时前
Linux——MySql数据库
linux·数据库
喵叔哟6 小时前
第4章:Cypher查询语言基础
数据库