博客 > 术业专攻> Linux基础> 系统与优化> MySQL数据库增量备份的操作 2019年08月29日 11:26:08
当数据库文件以及量级不大的时候,我们可以采用全量备份的策略来进行备份。但是当数据库文件有一定量级的时候,再使用全量备份,就显得有些笨拙了。
内网数据虽然没有特别重要,但是备份也是不可或缺的一个环节,朱子有言:“宜未雨而筹谋,勿临渴而掘井
”,这句话放在备份领域简直就是无法颠破的真理。
因此,在内网的数据,我们也做了全量备份,今天就来整理一下备份的脚本以及备份的策略以及备份的灾备恢复。
增量备份的成立依赖于mysql的bin-log原理,我们在数据库中的每一步增删改查操作都会记录在binlog日志当中,那么通过先对数据库进行一次全量备份,备份同时将binlog日志刷新,在这次备份之后的所有操作都会记录在新增的binlog日志当中,在增量备份当中我们只需要对增加的binlog进行备份,就实现了对不断增加内容的数据库的完美备份了。
当数据库出现异常的时候,我们可以先恢复最近一次的全量备份,接着将增量备份的文件一个一个按顺序恢复即可实现原来数据库的恢复。
执行增量备份的前提条件是MySQL打开binlog
日志功能,在my.cnf
中加入
log-bin=/data/mysql/mysql-bin #“log-bin=”后的字符串为日志记载目录,如果不指定位置的话,默认在mysql的data目录下。
#!/bin/bash dumpdate=$(date +%H%M%S) filedate=$(date +%y%m%d) mysqldump=/usr/local/mysql/bin/mysqldump mulu=/backup/sqlbackup/all/$filedate if [ ! -d $mulu ];then mkdir -p $mulu fi $mysqldump --quick --events --all-databases --flush-logs --delete-master-logs --single-transaction > ${mulu}/all${dumpdate}.sql sleep 5
参数:
--quick,-q
--events, -E
--all-databases , -A
--flush-logs
这一项必须带上
。--delete-master-logs
--single-transaction
#!/bin/bash export LANG=en_US.UTF-8 BakDir=/backup/sqlbackup/add LogFile=$BakDir/binlog.log BinDir=/usr/local/mysql/data BinFile=/usr/local/mysql/data/mysql-bin.index mysqladmin=/usr/local/mysql/bin/mysqladmin $mysqladmin 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 sleep 5
针对binlog的增量备份。
方式 | 定时任务 | 备注 |
增量备份 | 0 3 0 /bin/bash /backup/sqlbakall.sh | 每周日凌晨三点备份 |
全量备份 | 0 3 1-6 /bin/bash /backup/sqlbakadd.sh | 每周一到周六凌晨三点备份 |
这样就实现了数据库的增量备份。其中全量备份则使用mysqldump将所有的数据库导出,每周日凌晨三点执行,并会删除上周留下的binlog(mysql-bin.00000*)。增量备份会在每周一到周六的凌晨三点执行,执行的动作是将一周生成的binlog复制到指定的目录。
关于灾备恢复。
先恢复
最近一次的全量备份,让数据库追溯到最近一次的完整状态。具体恢复命令如下:
mysql -uroot -p123456 < all104528.sql
mysqlbinlog master-bin.000007 | mysql -uroot -p123456 mysqlbinlog master-bin.000008 | mysql -uroot -p123456 mysqlbinlog master-bin.000009 | mysql -uroot -p123456
注:当执行恢复操作的时候,由于数据量较大,可以暂时关闭binlog的记录。
突然想,为何不优化一下呢?
说干就干。
优化思路就是把旧的binlog保存在oldbinlog目录当中。
全量备份:
#!/bin/bash dumpdate=$(date +%H%M%S) filedate=$(date +%y%m%d) mysqldump=/usr/local/mysql/bin/mysqldump mulu=/backup/sqlbackup/all/$filedate if [ ! -d $mulu ];then mkdir -p $mulu fi $mysqldump --quick --events --all-databases --flush-logs --delete-master-logs --single-transaction > ${mulu}/all${dumpdate}.sql sleep 5 cd /backup/sqlbackup/add/ \mv master-bin.0000* oldbinlog
注意要创建这个oldbinlog目录。
这样,当服务出问题的时候,直接根据all目录下的全量备份进行恢复,然后根据add目录下的增量备份进行恢复即可。
© 2018 www.qingketang.net 鄂ICP备18027844号-1
武汉快勤科技有限公司 13554402156 武汉市东湖新技术开发区关山二路特一号国际企业中心6幢4层7号
扫码关注,全站教程免费播放
订单金额:
支付金额:
支付方式: