时间:2021-07-01 10:21:17 帮助过:7人阅读
(1)从宕机崩溃的 master 上尝试保存二进制日志事件(binlog events);
(2)识别含有最新更新的 slave 服务器;
(3)应用差异的中继日志(relay log)到其他的 slave;
(4)应用从 master 保存的二进制日志事件(binlog events);
(5)提升一个 slave 为新的 master 服务器;
(6)将其他的 slave 连接指向新的 master 进行主从复制;
MHA 软件由两部分组成,Manager 工具包和 Node 工具包,具体的说明如下。
Manager 工具包主要包括以下几个工具:
? masterha_check_ssh 检查 MHA 的 SSH 配置状况
? masterha_check_repl 检查 MySQL 复制状况
? masterha_manger 启动 MHA
? masterha_check_status 检测当前 MHA 运行状态
? masterha_master_monitor 检测 master 是否宕机
? masterha_master_switch 控制故障转移(自动或者手动)
? masterha_conf_host 添加或删除配置的 server 信息
Node 工具包(这些工具通常由 MHA Manager 的脚本触发,无需人为操作)主要包括以下几 个工具:
? save_binary_logs 保存和复制 master 的二进制日志
? apply_diff_relay_logs 识别差异的中继日志事件并将其差异的事件应用于其他的 slave
? filter_mysqlbinlog 去除不必要的 ROLLBACK 事件(MHA 已不再使用这个工具)
? purge_relay_logs 清除中继日志(不会阻塞 SQL 线程)
注意:为了尽可能的减少主库硬件损坏宕机造成的数据丢失,因此在配置 MHA 的同时建议 配置成 MySQL 5.5 的半同步复制。关于半同步复制原理各位自己进行查阅。(不是必须)
MHA 环境说明
所有操作系统均为 centos 7.x 64bit,涉及到主从复制环境搭建后面会简单演示步骤,但 是相关的安全复制不会详细说明,MySQL Replication 需要注意的问题:
角色 | IP地址 | 主机名 | ServerID | 数据库类型 |
Primary Master | 192.168.200.111 | server01 | 1 | 写 |
Secondary Master | 192.168.200.112 | server02 | 2 | 写 |
Slave1 | 192.168.200.113 | server03 | 3 | 读 |
Slave2 | 192.168.200.114 | server04 | 4 | 读 |
Manager | 192.168.200.115 | server05 | - | 监控复制组 |
其中 Primary Master 对外提供写服务,备选 Secondary Master(实际的 slave 提供读服务, slave1和slave2也提供相关的读服务,一旦Primary Master宕机,将会把备选Secondary Master 提升为新的 Primary Master,slave1 和 slave2 指向新的 master。
基于 MHA 的MySQL高可用-CentOS7(理论)
标签:ip地址 master 故障切换 识别 故障 上进 保存 基础 工具包