MySQL高可用架构学习

MHA(Master HA)是一款开源的由Perl语言开发的MySQL高可用架构方案。它为MySQL 主从复制架构提供了 automating master failover 功能。MHA在监控到 master 节点故障时,会提升其中拥有最新数据的 slave 节点成为新的 master 节点,在此期间,MHA 会通过于其它从节点获取额外信息来避免一致性方面的问题。MHA 还提供了 master 节点的在线切换功能,即按需切换 master / slave 节点。

MHA软件由两部分组成,Manager工具包和Node工具包,具体的说明如下:

MHA Manager(管理节点) 作用
masterha_check_ssh 检查MHA的
ssh-key masterha_check_repl 检查主从复制情况
masterha_manger 启动MHA
masterha_check_status 检测MHA的运行状态
masterha_master_monitor 检测master是否宕机
masterha_master_switch 手动故障转移
masterha_conf_host 手动添加server信息
masterha_secondary_check 建立TCP连接从远程服务器
masterha_stop 停止MHA

Node工具包主要包括以下几个工具:

MHA Node(数据节点) 作用
save_binary_logs 保存宕机的master的binlog
apply_diff_relay_logs 识别 relay logs的差异对比
filter_mysqlbinlog 防止回滚事件,截取日志
purge_relay_logs 清除中继日志relay_logs

MHA故障发现与转移过程

转移过程:保证所有从属服务器之间数据是一致的。

比对后,将差异数据发往每一个从属服务器。所有从属服务器日志与主服务器保持同步。

主服务器选择方案:

VIP虚拟IP漂移,将原有的VIP指向新的主服务器。大概有几秒中时间。

old master恢复后:

总结一下

优点:

  • 由perl语言开发的开源工具
  • 可以支持基于GTID的复制模式
  • 当主DB不可用时,从多个从服务器中选举出来新的主DB
  • 提供了主从切换和故障转移功能,在线故障转移时不易丢失数据
  • 同一个监控节点可以监控多个集群

缺点:

  • 需要编写脚本或利用第三方工具来实现VIP的配置
  • MHA启动后只监控主服务器是否可用,没办法监控从服务器
  • 需要基于SSH免认证登陆配置,存在一定的安全隐患
  • 没有提供从服务器的读负载均衡功能
相关推荐
问道飞鱼25 分钟前
【数据库知识】MySQL 多表关联高效实现指南:场景化方案与底层原理
数据库·mysql·多表关联
dblens 数据库管理和开发工具33 分钟前
MySQL :5.7与8.0版创建用户与授权、密码认证插件、角色、密码过期策略
数据库·mysql·dblens·mysql创建用户·mysql设置密码·mysql用户授权
卡尔特斯1 小时前
Mysql ERROR 1524 (HY000): Plugin 'mysql_native_password' is not loaded
mysql
小韩博1 小时前
小迪第42课:PHP应用&MYSQL架构&SQL注入&跨库查询&文件读写&权限操作
sql·mysql·网络安全·架构·php
北极糊的狐2 小时前
若依报错org.springframework.dao.DataIntegrityViolationException
数据库·mysql
嘻哈baby3 小时前
MySQL索引设计避坑指南:这些错误别再犯了
mysql
q_19132846953 小时前
基于Springboot+Vue.js的工业人身安全监测系统
vue.js·spring boot·后端·mysql·计算机毕业设计·串口通讯
子夜江寒4 小时前
Python 操作 MySQL 数据库
数据库·python·mysql
野蛮人6号4 小时前
p29 docker08-docker基础-本地目录挂载 无法正确添加mysql 点击更新后data没有正常显示
mysql·docker·容器
Alex Gram4 小时前
SQL Server实时同步到MySQL:构建高效跨数据库数据流通方案
数据库·mysql·sqlserver