MySQL数据库如何用脚本备份全库和增量备份-创新互联

MySQL数据库如何用脚本备份全库和增量备份?针对这个问题,今天小编总结这篇有关数据库备份的文章,可供感兴趣的小伙伴们参考借鉴,希望对大家有所帮助。

创新互联建站是专业的甘谷网站建设公司,甘谷接单;提供网站设计、成都网站设计,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行甘谷网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!

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 "跳过最新二进制日志文件,备份完成!!!"

以上就是MySQL数据库用脚本备份全库和增量备份的具体实现方法,看完之后是否有所收获呢?如果想了解更多相关内容,欢迎关注创新互联行业资讯!

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


网站标题:MySQL数据库如何用脚本备份全库和增量备份-创新互联
分享网址:http://ybzwz.com/article/cdpcij.html