MySQL 自动化备份脚本

全库备份

vim all_db_bak.sh

#!/bin/bash
#MySQL 全库备份

PATH="/usr/local/mysql/bin:$PATH"
BAK1=/bak1
BAK2=/bak2
TIME=$(date +"%F:%H:%M:%S")
USER=root
PASS=123456

if [ ! -d $BAK1 -o ! -d $BAK2 ];then
	mkdir $BAK1
	mkdir $BAK2
	mysqldump -u$USER -p$PASS --all-databases > /$BAK1/all_${TIME}.sql
	cp $BAK1/all_${TIME}.sql $BAK2
	echo -e "\033[32mMySQL数据已全库备份到 ${BAK2} 目录\033[0m"
else
	mysqldump -u$USER -p$PASS --all-databases > /$BAK1/all_${TIME}.sql
	cp $BAK1/all_${TIME}.sql $BAK2
	echo -e "\033[32mMySQL数据已全库备份到 ${BAK2} 目录\033[0m"
fi

增量备份

  • 开启 mysql 的 logbin 日志功能
[mysqld]
log-bin = "/home/mysql/logbin.log"
binlog-format = ROW
log-bin-index = "/home/mysql/logindex"
binlog_cache_size=32m
max_binlog_cache_size=512m
max_binlog_size=512m

重启 mysql,其中路径 /home/mysql 的用户和组要改成 mysql

  • 建立以下目录
mkdir -p /home/mysql/backup/daily
  • 增量备份脚本
vim binlogbak.sh

#!/bin/bash
PATH="/usr/local/mysql/bin:$PATH"
export LANG=en_US.UTF-8
BakDir=/home/mysql/backup/daily
BinDir=/home/mysql
LogFile=/home/mysql/backup/binlog.log
BinFile=/home/mysql/logindex.index
#注意修改密码
mysqladmin -uroot -p123456 flush-logs
#这个是用于产生新的 mysql-bin.00000* 文件
Counter=`wc -l $BinFile |awk '{print $1}'`
NextNum=0
#这个 for 循环用于比对 $Counter,$NextNum 这两个值来确定文件是不是存在或最新的
for file in `cat $BinFile`
do
    base=`basename $file`
    #basename用于截取mysql-bin.00000*文件名,去掉./mysql-bin.000005前面的./
    NextNum=`expr $NextNum + 1`
    if [ $NextNum -eq $Counter ]
    then
        echo $base skip! >> $LogFile
    else
        dest=$BakDir/$base
        if(test -e $dest)
        #test -e用于检测目标文件是否存在,存在就写exist!到$LogFile
        then
            echo $base exist! >> $LogFile
        else
            cp $BinDir/$base $BakDir
            echo $base copying >> $LogFile
        fi
    fi
done
echo `date +"%Y年%m月%d日 %H:%M:%S"` Bakup succ! >> $LogFile

开启计划任务

vim /etc/crontab
 
#每个星期日凌晨 3:00 执行完全备份脚本
0 3 * * 0 /home/mysql/all_db_bak.sh >/dev/null 2>&1
#周一到周六凌晨3:00做增量备份
0 3 * * 1-6 /home/mysql/binlogbak.sh >/dev/null 2>&1

crontab /etc/crontab  		#使上述定时任务生效
crontab -l				    #查看定时任务
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

头发莫的了呀

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

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

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

打赏作者

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

抵扣说明:

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

余额充值