由于公司出于容灾的需要,需要对重要的数据进行全量备份。我们的数据库结构是一主多从结构。所以我全量备份的是从数据库,并且是按定时任务,每6个小时备份一次。
脚本内容如下
#!/bin/sh
bak_time=`date +%Y%m%d%H`
#备份服务器地址
bak_server="10.10.10.21"
now_date_str=`date +"%Y%m%d%H%M%S"`
message_file="/tmp/login"$now_date_str".txt"
wx_sender="tomson"
#本机ip地址
server_ip="192.168.3.13"
date '+%Y-%m-%d %H:%M:%S'
is_bakup_running=`ps -ef | grep "mysqlbak.sh" | grep -v grep -c`
if [ $is_bakup_running -gt '1' ] ; then
echo "bakup now ruunnning"
exit
fi
#暂停mysql服务
/etc/init.d/mysql stop
is_mysql_run=`ss -ntl | grep ":3306" -c`
if [ $is_mysql_run -eq '0' ] ; then
#对mysql整个文件进行压缩备份
/usr/bin/tar -cvzf /tmp/mysql5.7.37_$bak_time.tar.gz /usr/local/mysql5.7.37
#切换到bakup用户,通过私钥访问形式拷贝到远端存储
su bakup -c "scp /tmp/mysql5.7.37_$bak_time.tar.gz $bak_server:/data/mysqlbak/"
#删除刚才压缩的备份程序
rm -f /tmp/mysql5.7.37_$bak_time.tar.gz
#启动mysql服务
/etc/init.d/mysql start
fi
#因为这是一个从数据库,所以启动后,查看mysql的同步服务是否正常启动
is_sync_ok=`mysql -uroot -p'dewef2wfewfwefew' --show-warnings=false -A -e "show slave status \G" | egrep "Slave_IO_Running:|Slave_SQL_Running:" | awk -F":" '{print $2}' | tr "\n" " " | sed 's/ //g'`
#从数据库启动失败,就发一个错误日志文件到一个webdav文件服务器,企业微信会自动把消息发送给相关管理人员
if [ $is_sync_ok != "YesYes" ] ; then
echo $wx_sender > $message_file
echo "Server "$server_ip"sync DB error " >> $message_file
echo "mysql slave error,please check now" >> $message_file
curl -u "dd:tdew123" -vT $message_file http://10.10.57.185:88/wxmessage/
rm -f $message_file
fi
date '+%Y-%m-%d %H:%M:%S'