mysql增量备份脚本_mysql全量备份、增量备份脚本

做运维这个工作,mysql备份是必不可少的,下面分享下我在使用的全量备份、增量备份脚本,供大家参考。

mysqldump增量备份配置

执行增量备份的前提条件是MySQL打开binlog日志功能

查找mysql的配置文件my.cnf

find / -name my.cnf

默认路径一般为 /etc/my.cnf

vim /etc/my.cnf

在[mysqld]下面增加

log-bin=mysql-bin

“log-bin=”后的字符串为日志记载目录,可根据情况自行更改,也可以默认不变。

如我的记载目录设置为:log-bin=/usr/local/mysql/var/data/mysql-bin

设置完成后需要重启mysql服务。

mysql备份文件保存位置

先创建保存mysql备份文件的位置,一般建议放在不同于MySQL数据目录的磁盘上。

mkdir -p /home/mysql/backup/daily

我的mysql全量备份文件存放位置:/home/mysql/backup

我的mysql全量备份文件存放位置:/home/mysql/backup/daily

mysql全量备份脚本

vim /root/js/mysql-fully-bak.sh

#!/bin/bash

# Program

# use mysqldump to Fully backup mysql data per week!

# History

# Path

BakDir=/home/mysql/backup

LogFile=/home/mysql/backup/bak.log

Date=`date +%Y%m%d`

Begin=`date +"%Y年%m月%d日 %H:%M:%S"`

cd $BakDir

DumpFile=$Date.sql

GZDumpFile=$Date.sql.tgz

/usr/local/mysql/bin/mysqldump -uroot -p123456*** --quick --events --all-databases --flush-logs --delete-master-logs --single-transaction > $DumpFile

echo \@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ >> $LogFile

/bin/tar -zvcf $GZDumpFile $DumpFile

/bin/rm $DumpFile

#只保留过去四周的数据库内容

#count=$(ls -l  *.tgz |wc -l)

#if [ $count -ge 5 ]

#then

#file=$(ls -l *.tgz |awk '{print $9}'|awk 'NR==1')

#/bin/rm -f  $file

#fi

#

Last=`date +"%Y年%m月%d日 %H:%M:%S"`

echo $GZDumpFile >> $LogFile

echo 开始:$Begin 结束:$Last  mysql-fully-bak successful !!! >> $LogFile

echo   >> $LogFile

#/bin/rm -f $BakDir/daily/*      #进行全量备份后删除增量备份文件

mysql增量备份脚本

vim /root/js/mysql-daily-bak.sh

#!/bin/bash

# Program

# use cp to backup mysql data everyday!

# History

# Path

BakDir=/home/mysql/backup/daily         #增量备份时复制mysql-bin.00000*的目标目录,提前手动创建这个目录

BinDir=/usr/local/mysql/var/data                 #mysql数据存放目录

LogFile=/home/mysql/backup/bak.log             #备份日志存放目录

BinFile=/usr/local/mysql/var/data/mysql-bin.index       #mysql数据目录下的index文件

Date=`date +%Y%m%d`

Begin=`date +"%Y年%m月%d日 %H:%M:%S"`

/usr/local/mysql/bin/mysqladmin -uroot -p123456****  flush-logs

#这个是用于产生新的mysql-bin.00000*文件

Counter=`wc -l $BinFile |awk '{print $1}'`

NextNum=0

#这个for循环用于比对$Counter,$NextNum这两个值来确定文件是不是存在或最新的

echo \######################################################  >> $LogFile

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! > /dev/null

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

Last=`date +"%Y年%m月%d日 %H:%M:%S"`

echo 开始:$Begin 结束:$Last$Next mysql-daily-backup successful !!! >> $LogFile

echo    >> $LogFile

ls -l -h  $BakDir

设置crontab任务,定时执行备份脚本

[root@jiangwei backup]# crontab -e

添加以下任务

#每个星期日凌晨3:00执行完全备份脚本

0 3 * * 0 /root/js/mysql-fully-bak.sh >/dev/null 2>&1

#周一到周六凌晨3:00做增量备份

0 3 * * 1-6 /root/js/mysql-daily-bak.sh >/dev/null 2>&1

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值