mysql增量备份二进制日志,mysql二进制日志增量备份脚步

#!/bin/bash

#定义用户名及密码

host=

user=

userPWD=

#定义数据库

database=

mysqladmin -h$host -u$user  flush-logs

daily_databakDir=/backdir

#定义MYSQL数据目录

mysqlDataDir=/mysql5.5/data

eMailFile=$daily_databakDir/email.txt

#eMail=

DATE=`date +%Y%m%d%H%M%S`

logFile=$daily_databakDir/mysql$DATE.log

#echo "       " > $eMailFile

#echo "-----------------------" >> $eMailFile

#echo $(date +"%y-%m-%d %H:%M:%S") >> $eMailFile

#echo "-------

#

#------------------" >> $eMailFile

TIME=$(date "-d 40 day ago" +%Y%m%d%H%M%S)

StartTime=$(date -d "-60 minute" +"%Y-%m-%d %H:%M:%S")

echo “Delete 40 days before the log” >>$eMailFile

mysql -h$host -u$user  -e "purge master logs before ${TIME}" && echo "delete 40 days before log" |tee -a $eMailFile #删除10天前的2进制文件

filename=`cat $mysqlDataDir/mysql-bin.index |awk -F "/" '{print $2}'` # 2进制文件

for i in $filename

do

#echo "$StartTime start backup binlog" >> $eMailFile

mysqlbinlog -h$host -u$user -d $database --start-datetime="$StartTime" $mysqlDataDir/$i >> $daily_databakDir/daily$DATE.sql |tee -a $eMailFile

done

if [ $? = 0 ]

then

# 删除mtime>32的增量日志备份文件

find $daily_databakDir -name "*.log" -type f -mtime +32 -exec rm {} ; > /dev/null 2>&1

cd $daily_databakDir

tar -cvzf $daily_databakDir/$database$DATE.tar.gz daily$DATE.sql

# >>/dev/null 2&1

#scp 至另一台服务器

echo "Daily backup succeed" >>$eMailFile

else

echo "Daily backup fail"  >>$eMailFile

#mail -s "MySQL Backup" $eMail < $eMailFile #备份失败之后发送邮件通知

fi

cat $eMailFile > $logFile

# 删除mtime>32的增量日志备份文件

find $daily_databakDir -name "*.log" -type f -mtime +32 -exec rm {} ; > /dev/null 2>&1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值