Mysql实战之高可用HMA
author:JevonWei
版权声明:原创作品
主节点高可用
MHA是一款开源的MySQL的高可用程序,他为MySQL主从复制架构提供了automating master failover功能。MHA在监控到master节点故障时,会提升
其中拥有最新数据的slave节点成为新的master节点。在此期间,MHA会通过其他从节点获取额外信息来避免一致性方面的额问题。MHA还提供了master
节点切换功能,即按需切master/slave节点
MHA服务有两种角色,MHA Manager(管理节点)和HMA Node(数据节点)
MHA Manager:通常部署在一台独立机器上管理多个master/slave集群,每个master/slave集群称作一个application;
MHA node:运行在每台MySQL服务器上(master/slave/manager),他通过监控具备解析和清理logs功能的脚本来加快故障转移。
MHA组件
Manager节点
-masterha_check_ssh:MHA依赖的SSH环境检测工具
-masterha_check_repl:MySQL复制环境检测工具
-masterha_manager:MHA服务主程序
-masterha_check_status:MHA运行状态检测工具
-masterha_master_monitor:MySQL master节点可用性检测工具
-masterha_master_switch:master节点切换工具
-masterha_conf_host:添加或删除配置节点
-masterha_stop:关闭MHA服务的工具
Node节点
-save_binary_logs:保存和复制master的二进制日志
-apply_diff_relay_logs:识别差异的中继日志事件并应用于其他slave
-filter_mysqlbinlog:去除不必要的ROLLBACK事件(MHA已不在使用这个工具)
-purge_relay_logs:清除中继日志(不会阻塞SQL线程)
自定义扩展
-sccondary_check_script:通过多条网络路由检测master的可用性
-master_ip_failover_script:更新application使用的masterrip
-shutdown_script:强制关闭master节点
-report_script:发送报告
-init_conf_load_script:加载初始化配置参数
-master_ip_online_change_script:更新master节点ip地址
构建高可用HMA架构
节点角色
mysql-master 172.16.252.82
mysql-slave1 172.16.252.92
mysql-slave2 172.16.252.100
m