fdeli 发表于 2013-9-18 09:33:34

mysql主从+keepalived线上恢复解决方案

最近一个项目需要做一个mysql+keepalived高可用主从同步,配起来当然轻车熟路,但想到如何在主库挂掉,从库接管后,以最快的速度恢复数据,并让主库重新接管,所以整理了下思路,编写了如下脚本,供大家参考
mysql主从,以及keepalived高可用配置本博传送门:

一.备份从库当前数据库注:以下的所有配置需要在数据库未运转状态下进行,建议做一个iptables规则禁止非管理员IP访问主从服务器IP,以及VIP,这样既能保证管理员可SSH远程登陆配置,又能恢复主从环境,待配置完成后解除禁止即可。# vi /etc/rc.d/mysql_bak.sh-------------------------#!/bin/bash
# 环境变量PATH=/bin:/usr/bin:/sbin:/usr/sbin; export PATHexport LANG=C
# 日常备份目录basedir=/backup/daily/
# 数据库账户user=rootpasswd=123456
# mysql备份目录mysql_db_bak=$basedir/$(date +%F_%H%M)[ ! -d "$mysql_db_bak" ] && mkdir -p $mysql_db_bak
# mysql下所有库名称db_name=("information_schema" "mysql" "test_db1" "test_db2" "test_db3" "test_db4")
# 1.备份MySQL数据库for((i=0; i!=${#db_name[@]}; ++i)){mysqldump -u $user -p$passwd --opt --skip-lock-tables --flush-logs --database ${db_name} > $mysql_db_bak/${db_name}.sql}-------------------------
二.复制从(192.168.7.9)数据库备份到主库(192.168.7.12)# vi /etc/rc.d/scp_mysql.sh----------------------#/bin/bash# 环境变量PATH=/bin:/usr/bin:/sbin:/usr/sbin; export PATHscp /backup/daily/2013-09-10_1258/* 192.168.7.9:/tmp----------------------
三.恢复主库(192.168.7.9)# vi /etc/rc.d/recover_mysql.sh------------------------------------#/bin/bash# 环境变量PATH=/bin:/usr/bin:/sbin:/usr/sbin; export PATHexport LANG=C
# 数据库账户user=rootpasswd=123456
# # mysql下所有库名称db_name=("information_schema" "mysql" "test_db1" "test_db2" "test_db3" "test_db4")
# 恢复MySQL数据库cd /tmpfor((i=0; i!=${#db_name[@]}; ++i)){mysql -u $user -p$passwd -e "drop database ${db_name};"mysql -u $user -p$passwd -e "create database ${db_name};"mysql -u $user -p$passwd ${db_name} < ${db_name}.sql}
# 开启从库mysql -u $user -p$passwd -e "stop slave;"mysql -u $user -p$passwd -e "reset slave;"# 设置从库连接主库的相关参数,可利用相关命令查看mysql -u $user -p$passwd -e "change master to master_host='192.168.7.9',master_user='slave',master_password='123456#',master_log_file='bin.000029',master_log_pos=106 ";mysql -u $user -p$passwd -e "start slave;"# 查看主从是否连接成功mysql -u $user -p$passwd -e "show slave status\G;"------------------------------------
四.查看主从同步信息1.查看主库binlog日志以及偏移量# mysql -u root -p123456 -e "show master status"2.查看从库是否连接到主库# mysql -u root -p123456 -e " show slave status\G;"
注:实际操作中发现,一旦VIP切换后有一定几率造成主从服务器都会同时获取到该虚IP,导致主从数据库冲突,无论重启keepalived与否都无法干掉该VIP,目前我的临时解决方案是将两台服务器均重新启动,大家如果有更好的方法请留言告知我,不胜感谢。

x625802392 发表于 2013-11-26 12:16:47

听君一席话,省我十本书!

泪~~ 发表于 2014-1-4 09:27:29

我难过的是你在问我难过什么我害怕的是把我害怕的事情说出来
页: [1]
查看完整版本: mysql主从+keepalived线上恢复解决方案