mysql数据库二进制备份_MySQL数据库如何创建全库及二进制增量备份脚本

本文详细介绍了如何使用MySQL命令行工具创建全库备份脚本,包括覆盖所有数据库的完整备份,以及二进制增量备份脚本,用于高效恢复数据库。通过实例演示了如何设置参数、执行备份和检查备份状态,同时提到了删除旧备份的策略。
摘要由CSDN通过智能技术生成

MySQL数据库如何创建全库及二进制增量备份脚本

发布时间:2020-05-25 11:52:55

来源:51CTO

阅读:206

作者:三月

下面讲讲关于MySQL数据库如何创建全库及二进制增量备份脚本,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完MySQL数据库如何创建全库及二进制增量备份脚本这篇文章你一定会有所受益。

1、全库备份脚本如下:#!/bin/bash

############### 定义默认值   #################

user='root'

passwd='123.com'

host='localhost'

today=`date '+%F'`

dump_cmd='/usr/local/mysql/bin/mysqldump'

full_backupdir="/opt/database/full_backup/"

email='916551516@qq.com'

###################   加载变量并定义脚本用法  ###################

USAGE(){

echo -e "\033[33m

$0 脚本用法:

-u: 指定备份用户(默认是root)

-p: 指定用户密码(默认密码为“123.com”)

-h: 指定备份主机(默认是本机)

-d: 指定要备份的数据库(默认备份所有库)

\033[0m"

}

if [[ $1 == '--help' || $1 == '-h' ]];then

USAGE

exit 0

fi

######################   对选项进行赋值       ###################

while getopts ":u:p:h:d:" optname;do

case "$optname" in

"u")

user=$OPTARG

;;

"p")

passwd=$OPTARG

;;

"h")

host=$OPTARG

;;

"d")

db=$OPTARG

;;

":")

echo "此选项没有值!"

;;

"*")

echo "错误信息..."

;;

"?")

echo "不知道此选项..."

;;

esac

done

#############  对要备份的库进行判断并执行备份操作   ###############

[ -d ${full_backupdir} ] || mkdir -p ${full_backupdir}

cd ${full_backupdir}

: > err.log

if [ ${#db} -eq 0 ];then

${dump_cmd} -u${user} -p${passwd} -h${host} -A -F  > ${today}.sql 2> err.log

status=$?

sqlname="${today}.sql"

else

${dump_cmd} -u${user} -p${passwd} -h${host} --databases $db -F  > ${today}.${db}.sql 2> err.log

status=$?

sqlname="${today}.${db}.sql"

fi

############  对备份状态进行判断  #####################

if [ ${status} -eq 0 ];then

tar zcf ${sqlname}.tar.gz ./${sqlname}

rm -f ${sqlname}

###########  如果失败,则发送报警邮件到指定邮箱 ################

else

echo "备份数据库失败,错误日志如上所示!!!" >> err.log

mail -s "mysql backup" $email < err.log

fi

############  删除二十天前的备份文件  ##############

find . -type f -name "*.tar.gz" -mtime +20 -delete

2、二进制增量备份脚本#!/bin/bash

####################### 定义初始值  #############################

user='root'

passwd='123.com'

datadir="/usr/local/mysql/data"

backupdir="/opt/database/dailybackup/"

dump_cmd='/usr/local/mysql/bin/mysqlbinlog'

[ -d ${backupdir} ] || mkdir -p ${backupdir}             #判断备份文件存放路径是否存在

cd ${datadir}           #切换至mysql的数据存放路径

sum=`cat bin_log.index | wc -l`   #取得所有二进制日志文件总数

/usr/local/mysql/bin/mysql -u${user} -p${passwd} -e "flush logs" &> /dev/null   #在备份前刷新二进制日志文件

nextnum=0        #定义一个初始值为0

backupsum=0

for file in `cat bin_log.index`         #对所有二进制日志文件进行遍历

do

binlogname=`basename $file`         #获取二进制日志文件名

#如果当前备份的文件数目比总数小(新刷新的二进制文件不需要备份)

if [ $nextnum -lt $sum ];then

[ -f ${backupdir}${binlogname} ] || cp -a ${file} ${backupdir}${binlogname}   #如果备份目录下不存在该二进制文件,则进行copy动作

let nextnum++      #对备份成功数量进行增加

fi

done

echo "跳过最新二进制日志文件,备份完成!!!"

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值