Centos7用shell做一个Mysql全量备份的脚本


  由于公司出于容灾的需要,需要对重要的数据进行全量备份。我们的数据库结构是一主多从结构。所以我全量备份的是从数据库,并且是按定时任务,每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'
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

机核动力

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值