MHD高可用

MHA优点:

1.MHA能够在短的时实现故障检测与故障转移

2.在10-30秒内,MHA能够很好的解决复制过程中数据不一致的问题

3.由于不需要在现有的replication中添加额外的服务器,仅需要一个manager节点,所以能大大节约服务器数量

4.安装简单,无性能损耗,以及不需要修改现有的复制部署

5.当Master出现故障时,它可以自动将最新数据的Slave提升为新的Master,然后将所有其他的Slave重新指向新的Master

MHA工作流程

1.将宕机的master二进制日志保存下来

2.找到binlog位置点最新的slave

3.在binlog位置最新的slave上用relay log 修复其他slave

4.将宕机的master上保存下来的二进制日志恢复到含有最新位置点的slave上

5.将含有最新位置点binlog所在的slave提升为master

6.将其他slave重新指向新提升的master,并开启主从复制

MHA框架图

MHD高可用

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      #建立TCP连接从远程服务器

masterha_stop         #停止MHA

Node工具包主要工具

save_binary_logs      #保存宕机的master的binlog

apply_diff_relay_logs     #识别relay log的差异

filter_mysqlbinlog      #防止回滚事件

purge_relay_logs      #清除中继日志

实验环境

角色 主机名 IP地址 服务
Moniotor host mha-manager 200.200.2.10 mha-manager.mha-node
Master mysql-db01 200.200.2.11 mha-node
Slave01 mysql-db02 200.200.2.12 mha-node
Slave02 mysql-db03 200.200.2.13 mha-node

环境准备

四台设备都需要操作
hostname 改名
systemctl stop firewalld
setenforce 0
yum -y install lrzsz

安装数据库

除mha-manager不需要操作剩下三台都需要
rz
tar xf mysql-5.6.30-linux-glibc2.5-x86_64.tar.gz
mv mysql-5.6.30-linux-glibc2.5-x86_64/ /usr/local/mysql
创建数据库用户
useradd -M -s /sbin/nologin mysql
安装依赖包(四台都需要安装)
yum -y install autoconf
初始化数据user
cd /usr/local/mysql/scripts/
./mysql_install_db --user=mysql --datadir=/usr/local/mysql/data/ --basedir=/usr/local/mysql/
复制配置文件
\cp /usr/local/mysql/support-files/my-default.cnf /etc/my.cnf
复制启动脚本
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
配置环境变量
echo 'export PATH="/usr/local/mysql/bin:$PATH"' >> /etc/profile.d/mysql.sh
source /etc/profile
启动MySQL服务
systemctl daemon-reload
/etc/init.d/mysqld start
设置为开机自启
chkconfig --add mysqld
chkconfig mysqld on
设置用户与密码
mysqladmin -uroot password 123456;history -c
修改数据库db01:
vim /etc/my.con
[mysqld]
server_id=1    #主库server-id为1,从库不等于1;
log_bin=mysql-bin    #开启binlog日志;
user=mysql
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
socket=/tmp/mysql.sock
log_error=/usr/local/mysql/data/error.log
数据库02:
vim /etc/my.cnf
[mysqld]
server_id =2 数据库03:
vim /etc/my.cnf [mysqld]
server_id =3 三台设备重启服务: systemctl restart mysqld

主从备份对db01登陆数据库

mysql  -uroot -p123456
对用户进行授权
grant replication slave on *.* to rep@'200.200.2.%' identified by '123456';
查看节点
show master status
对两台从库进行配置
登陆数据库
mysql -uroot -p123456
授权
change master to master_host='200.200.2.11',master_user='rep',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=120;
启动从库
start slave
查看从库状态
show slave status\G

Slave_IO_Running: Yes
Slave_SQL_Running: Yes
必须全是Yes
禁止relay_log_purge自动清理功能 set global relay_log_purge=0 设置只读 set global read_only=1 退出数据库 设置禁用自动删除relay log永久生效 vim /etc/my.cmf [mysqld] server_id=10 log_bin=mysql-bin relay_log_purge=0 重启服务 /etc/init.d/mysqld restart

部署MHA

为所有节点进行配置
vim /etc/hosts
200.200.2.10 mha-manager
200.200.2.11 mysql-db01
200.200.2.12 mysql-db02
200.200.2.13 mysql-db03
安装依赖包
yum -y install perl-DBD-MySQL
上传数据包
rpm -ivh perl-Config-Tiny-2.23-2.3.noarch.rpm  rpm -ivh mha4mysql-node-0.56-0.el6.noarch.rpm yum -y localinstall perl-* rpm -ivh mha4mysql-manager-0.56-0.el6.noarch.rpm

在三台mysql数据库上部署

mysql -uroot -p123123
grant all privileges on *.* to mha@'192.168.2.%' identified by 'mha';
select user,host from mysql.user;

编辑配置文件

在MHA服务器上
mkdir -p /etc/mha
mkdir -p /var/log/mha/app1
mkdir -p /var/data/binlog
vim /etc/mha/app1.cnf 编辑mha配置文件 [server default] #设置manager日志 manager_log=/var/log/mha/app1/manager.log #设置manager工作目录 manager_workdir=/var/log/mha/app1 #设置master保存binlog的位置,以便MHA可以找到master日志 master_binlog_dir=/usr/local/mysql/data #设置监控的用户 user=mha #设置mha用户的密码 password=mha #设置监控主库,发送ping包的时间间隔,尝试三次没有回应的时候自动进行failover ping_interval=2 #设置复制用户的密码 repl_password=123456 #指定复制用户 repl_user=rep #设置ssh登录名 ssh_user=root [server1] hostname=200.200.2.11 port=3306 [server2] candidate_master=1 check_repl_delay=0 hostname=200.200.2.12 port=3306 [server3] hostname=200.200.2.13 port=3306

在db02与db03上添加rep用户

mysql -uroot -p123456
grant replication slave on *.* to rep@'200.200.2.%' identified by '123456';

对所有节点配置ssh信任

创建密钥对
ssh-keygen -t rsa -P '' -f ~/.ssh/id_rsa >/dev/null 2>&1
ssh-copy-id -i /root/.ssh/id_rsa.pub root@200.200.2.10
ssh-copy-id -i /root/.ssh/id_rsa.pub root@200.200.2.12
ssh-copy-id -i /root/.ssh/id_rsa.pub root@200.200.2.13
在ssh服务支持密钥认证
[root@mysql-db01 ~]# vim /etc/ssh/sshd_config
RSAAuthentication yes
PubkeyAuthentication yes
AuthorizedKeysFile      .ssh/authorized_keys
重启ssh服务
systemctl restart sshd

my.cnf配置

[mysqld]
server_id=2
user=mysql
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
socket=/tmp/mysql.sock
log_error=/usr/local/mysql/data/error.log
log_bin=mysql-bin
relay_log_purge=0
skip-name-resolve

启动测试

测试ssh
masterha_check_ssh --conf=/etc/mha/app1.cnf
测试复制
masterha_check_repl --conf=/etc/mha/app1.cnf 

启动MHA

nohup masterha_manager --conf=/etc/mha/app1.cnf --remove_dead_master_conf --ignore_last_failover < /dev/null > /var/log/mha/app1/manager.log 2>&1 &
masterha_check_status --conf=/etc/mha/app1.cnf

测试

准备工作
查看mysql-db2.mysql-db3的主从状态
测试
停掉主库
/etc/init.d/mysqld stop
此时登陆mysql-db2
发现slave状态为空
登陆mysql-db3
主库指向mysql-db2

配置VIP漂移

MHA脚本管理VIP

修改MHA配置文件
vim /etc/app1.cnf master_ip_failover_script=/usr/local/bin/master_ip_failover /usr/local/bin下创建脚本 vim /usr/local/bin/master_ip_failover #修改一下内容 my $vip = '200.200.2.199/24'; my $key = '0'; my $ssh_start_vip = "/sbin/ifconfig eth:$key $vip"; my $ssh_stop_vip = "/sbin/ifconfig eth:$key down"; [root@mha-manager ~]#chmod +x /usr/local/bin/master_ip_failover 在db01上手动绑定IP ifconfig ens32:0 200.200.2.199

测试VIP

启动MHA
nohup masterha_manager --conf=/etc/mha/app1.cnf --remove_dead_master_conf --ignore_last_failover < /dev/null > /var/log/mha/app1/manager.log 2>&1 &
宕掉db01
/etc/init.d/mysqld stop
此事vip漂移到db02
ip a | grep ens32
ens32:0漂移到db02上

配置binlog-server

修改mha配置文件

vim /etc/mha/app1.cnf
添加内容
[binlog]
no_master=1
hostname=200.200.2.10
master_binlog_dir=/var/data/binlog
安装5.7数据库调用命令
请参照主从复制的安装数据库步骤
备份binlog
MHA
cd /var/data/binlog/
mysqlbinlog -R --host=200.200.2.11 --user=mha --password=mha --raw --stop-never mysql-bin.000001 &
查看备份过来的日志
db-01
cd /var/data/binlog
ls
在mysql-slave01上刷新日志
mysql -uroot -p123456
flush logs
刷新完manager备份日志,新增一条日志
ls
上一篇:MHA架构部署


下一篇:MySQL——MHA高可用集群