文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2024-04-02 19:55

关注

脚本网盘链接下载。

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 "跳过最新二进制日志文件,备份完成!!!"
阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯