• ADADADADAD

    MySQL数据库全库备份及增量备份脚本[ mysql数据库 ]

    mysql数据库 时间:2024-11-29 10:09:02

    作者:文/会员上传

    简介:

    脚本网盘链接下载。1、全库备份脚本如下:#!/bin/bash############### 定义默认值 #################user='root'passwd='123.com'host='localhost'today=`date '+%F'`dump_cm

    以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。

    脚本网盘链接下载。

    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' ]];thenUSAGEexit 0fi###################### 对选项进行赋值 ###################while getopts ":u:p:h:d:" optname;docase "$optname" in"u")user=$OPTARG;; "p")passwd=$OPTARG ;;"h")host=$OPTARG ;;"d")db=$OPTARG;; ":")echo "此选项没有值!" ;;"*") echo "错误信息...";;"?")echo "不知道此选项...";;esacdone#############对要备份的库进行判断并执行备份操作 ###############[ -d ${full_backupdir} ] || mkdir -p ${full_backupdir}cd ${full_backupdir}: > err.logif [ ${#db} -eq 0 ];then${dump_cmd} -u${user} -p${passwd} -h${host} -A -F> ${today}.sql 2> err.logstatus=$?sqlname="${today}.sql"else${dump_cmd} -u${user} -p${passwd} -h${host} --databases $db -F> ${today}.${db}.sql 2> err.logstatus=$?sqlname="${today}.${db}.sql"fi############对备份状态进行判断#####################if [ ${status} -eq 0 ];thentar zcf ${sqlname}.tar.gz ./${sqlname}rm -f ${sqlname}###########如果失败,则发送报警邮件到指定邮箱 ################elseecho "备份数据库失败,错误日志如上所示!!!" >> err.logmail -s "mysql backup" $email < err.logfi############删除二十天前的备份文件##############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#定义一个初始值为0backupsum=0for file in `cat bin_log.index` #对所有二进制日志文件进行遍历dobinlogname=`basename $file` #获取二进制日志文件名#如果当前备份的文件数目比总数小(新刷新的二进制文件不需要备份)if [ $nextnum -lt $sum ];then [ -f ${backupdir}${binlogname} ] || cp -a ${file} ${backupdir}${binlogname} #如果备份目录下不存在该二进制文件,则进行copy动作let nextnum++#对备份成功数量进行增加fidoneecho "跳过最新二进制日志文件,备份完成!!!"
    MySQL数据库全库备份及增量备份脚本.docx

    将本文的Word文档下载到电脑

    推荐度:

    下载