MHA高可用部署及测试

MHA高可用部署及测试,MySQL高可用解决方案

目录

一.MHA特性
二.MHA工作机制
三.MHA适用的主从架构
四.MHA高可用环境的构建
4.1 实验环境
4.2 实验大概步骤
4.3 脚本相关说明
4.4 MHA部署过程
4.5 配置VIP的方式
五.MHA常用命令
六.注意事项
七.部署过程遇到的问题

一.MHA特性

1.主服务器的自动监控和故障转移

  MHA监控复制架构的主服务器,一旦检测到主服务器故障,就会自动进行故障转移。即使有些从服务器没有收到最新的relay log,MHA自动从最新的从服务器上识别差异的relay log并把这些日志应用到其他从服务器上,因此所有的从服务器保持一致性了。MHA通常在几秒内完成故障转移,9-12秒可以检测出主服务器故障,7-10秒内关闭故障的主服务器以避免脑裂,几秒中内应用差异的relay log到新的主服务器上,整个过程可以在10-30s内完成。还可以设置优先级指定其中的一台slave作为master的候选人。由于MHA在slaves之间修复一致性,因此可以将任何slave变成新的master,而不会发生一致性的问题,从而导致复制失败。

2.交互式主服务器故障转移


  可以只使用MHA的故障转移,而不用于监控主服务器,当主服务器故障时,人工调用MHA来进行故障故障。

3.非交互式的主故障转移

  不监控主服务器,但自动实现故障转移。这种特征适用于已经使用其他软件来监控主服务器状态,比如heartbeat来检测主服务器故障和虚拟IP地址接管,可以使用MHA来实现故障转移和slave服务器晋级为master服务器。

4.在线切换主服务器

  在许多情况下,需要将现有的主服务器迁移到另外一台服务器上。比如主服务器硬件故障,RAID控制卡需要重建,将主服务器移到性能更好的服务器上等等。维护主服务器引起性能下降,导致停机时间至少无法写入数据。另外,阻塞或杀掉当前运行的会话会导致主主之间数据不一致的问题发生。MHA提供快速切换和优雅的阻塞写入,这个切换过程只需要0.5-2s的时间,这段时间内数据是无法写入的。在很多情况下,0.5-2s的阻塞写入是可以接受的。因此切换主服务器不需要计划分配维护时间窗口(呵呵,不需要你在夜黑风高时通宵达旦完成切换主服务器的任务)。


二.MHA工作机制

MHA自动Failover过程解析

https://code.google.com/p/mysql-master-ha/wiki/Sequences_of_MHA
 
三.MHA适用的主从架构


https://code.google.com/p/mysql-master-ha/wiki/UseCases
 
四.MHA高可用环境的构建


4.1 实验环境


•Node1:192.168.10.216 (主)
•Node2:192.168.10.217 (从,主故障切换的备主)
•Node3:192.168.10.218 (从,兼MHA管理节点)
•VIP : 192.168.10.219
•Mysql:Percona-Server-5.6.16-rel64.2-569
•以上节点系统均为CentOS6.5 x64
 
4.2 实验大概步骤

A. 三节点配置epel的yum源,安装相关依赖包

B. 建立主从复制关系

C. ssh-keygen实现三台机器之间相互免密钥登录

D. 三节点安装mha4mysql-node-0.56,node3上安装mha4mysql-manager-0.56

E. 在node3上管理MHA配置文件

F. masterha_check_ssh验证ssh信任登录是否成功,masterha_check_repl验证mysql复制是否成功

G. 启动MHA manager,并监控日志文件

H. 测试master(Node1)的mysql宕掉后,是否会自动切换正常

I . 配置VIP,切换后从自动接管主服务,并对客户端透明


4.3 脚本相关说明

MHA node有三个脚本,依赖perl模块

save_binary_logs:保存和拷贝宕掉的主服务器二进制日志

apply_diff_relay_logs:识别差异的relay log事件,并应用到所有从服务器节点
purge_relay_logs:清除relay log日志文件


4.4 MHA部署过程

A.三节点配置epel的yum源,安装相关依赖包


rpm -Uvh Fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6
yum  -y install perl-DBD-MySQL  ncftp
 

B. 建立主从复制关系

在node1上:


mysql>grant replication slave  on *.* to 'rep'@'192.168.10.%' identified by 'geekwolf';
mysql>grant all on *.* to 'root'@'192.168.10.%' identified by 'geekwolf';
mysql>show master status;
 

拷贝node1的data目录同步到node2,node3
在node2 node3上:


mysql>change master  to  master_host='192.168.10.216', master_user='rep', master_password='geekwolf',master_port=3306, master_log_file='mysql-in.000006',master_log_pos=120,master_connect_retry=1;
mysql>start slave;
 

每个节点都做好mysql命令的软链

ln -s /usr/local/mysql/bin/* /usr/local/bin/

C. ssh-keygen实现三台机器之间相互免密钥登录
在node1(在其他两个节点一同)执行

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/b9dd9e6d29ae43066b7b219e52196208.html