MySQL 使用XtraBackup的shell脚本介绍

时间:2023-01-02 20:17:47

mysql_backup.sh是关于MySQL的一个使用XtraBackup做备份的shell脚本,实现了简单的完整备份和增量备份、以及邮件发送备份信息等功能。功能目前还比较简单,后续将继续完善和增加相关功能。参考了网上MySQL备份的脚本,如有不足的地方,欢迎大家拍砖!

1: 使用前,请先做一些配置选项修改,例如备份路径设置、连接数据库的账号密码等等。

2: 在BACKUP_DIR目录下,创建full、incr、logs、scripts四个目录,将mysql_backup.sh放置在scripts目录下。

#!/bin/bash 

 

###################################################################################



# This script is used for MySQL daily backup. it is a package of Xtrabackup shell

# script       #

#                                                                                 #

# #################################################################################

#                                                                                 #

# ScriptName    :    mysql_backup.sh                                              #

# Author        :    潇湘隐者                                              #

# CerateDate    :    2016-04-24                                  #

# Blogs        :   www.cnblogs.com/kerrycode                                    #

# @author       :   kerry2008code@qq.com                                          #

#*********************************************************************************#

# Version        Modified Date            Description                             #

#*********************************************************************************#

# V.1.0          2016-04-24          create the script for mysql daily backup     #

###################################################################################

 

 

 

BACKUP_DATE=$(date +%Y-%m-%d_%H_%M_%S)

BACKUP_DIR=/backup/mysql

FULLBACKUP_PATH=$BACKUP_DIR/full

INCRBACKUP_PATH=$BACKUP_DIR/incr

BACKUP_LOG_PATH=$BACKUP_DIR/logs

BACKUP_KEEP_DAY=7

MYSQL_CONF=/usr/my.cnf

INNOBACKUPEX=/usr/bin/innobackupex

MYSQL_CMD=/usr/bin/mysql

MYSQL_CONNECT="--host=127.0.0.1 --user=root --password=123456 --port=3306"

MAIL_FROM="root@`hostname`"

MAIL_TO=konglb@xxx.com


 

error()

{

 echo "$1" 1>&2

 exit 1

}

 

#before the backup, check the system enviroment setting and mysql status and so on

mysql_backup_check()

{

 

    if [ ! -d $FULLBACKUP_PATH ];then

        mkdir -p $FULLBACKUP_PATH

    fi

    

    if [ ! -d $INCRBACKUP_PATH ];then

        mkdir -p $INCRBACKUP_PATH

    fi

    

    if [ ! -d $BACKUP_LOG_PATH ];then

        mkdir -p $BACKUP_LOG_PATH

    fi

    

    

    if [ ! -x $INNOBACKUPEX ];then

       error "$INNOBACKUPEX did not exists"

    fi

    

    if [ ! -x $MYSQL_CMD ];then

       error "mysql client did not exists!"

    fi

    

     mysql_status=`netstat -nl | awk 'NR>2{if ($4 ~ /.*:3306/) {print "Yes";exit 0}}'`  

      

        if [ "$mysql_status" != "Yes" ];then  

          error "MySQL did not start. please check it"  

        fi

   

        if ! `echo 'exit' | $MYSQL_CMD -s $MYSQL_CONNECT` ; then  

         error "please check the user and password is correct!"  

        fi  

}

 

 

xtra_backup()

{

  if [ $# = 2 ];then

        $INNOBACKUPEX --defaults-file=$MYSQL_CONF $MYSQL_CONNECT  --no-timestamp  $1/full_$BACKUP_DATE>$2 2>&1

  elif [ $# = 3 ];then

        $INNOBACKUPEX  --defaults-file=$MYSQL_CONF $MYSQL_CONNECT  --no-timestamp --incremental  $1/incr_$BACKUP_DATE  --incremental-basedir $2 >$3 2>&1

  else

      error "the parameter is not correct"

  fi

}

 

 

lastest_fullback_dir()

{

    if [ -d $1 ]; then

        path=`ls -t $1 |head -n 1`

        if [  $path ]; then

            echo $path

        else

            error "lastest_fullback_dir(): 目录为空,没有最新目录"

        fi

    else

        error "lastest_fullback_dir(): 目录不存在或者不是目录"

    fi

}

 

 

mysql_full_backup()

{

    xtra_backup  $FULLBACKUP_PATH $BACKUP_LOG_PATH/full_$BACKUP_DATE.log

    

    if [ "${PIPESTATUS[0]}" -ne 0 ]; then

        (echo "Subject: MySQL Backup Failed: MySQL Backup failed on `hostname`";

      cat ${BACKUP_LOG_PATH}/full_${BACKUP_DATE}.log;

    ) | /usr/sbin/sendmail -O NoRecipientAction=add-to -f${MAIL_FROM} ${MAIL_TO}

    else

      (echo "Subject: MySQL Backup Success: MySQL Backup failed on `hostname`";

      cat ${BACKUP_LOG_PATH}/full_${BACKUP_DATE}.log;

    ) | /usr/sbin/sendmail -O NoRecipientAction=add-to -f${MAIL_FROM} ${MAIL_TO}

    fi

 

    

    cd $FULLBACKUP_PATH 

    

    ls -t | tail -n +$BACKUP_KEEP_DAY | xargs rm -rf

}

 

mysql_incr_backup()

{

 

  LATEST_FULL_BACKUP=`find $FULLBACKUP_PATH -mindepth 1 -maxdepth 1 -type d -printf "%P\n" | sort -nr | head -1` 

  

  LATEST_FULL_BACKUP_TIME=`stat -c %Y $FULLBACKUP_PATH/$LATEST_FULL_BACKUP`

  

  if [ $LATEST_FULL_BACKUP ];then

        #

        xtra_backup $INCRBACKUP_PATH  $FULLBACKUP_PATH/`lastest_fullback_dir $FULLBACKUP_PATH`  $BACKUP_LOG_PATH/incr_$BACKUP_DATE.log 

  else

        # the first incremental backup need do full backup first 

         xtra_backup $FULLBACKUP_PATH  $BACKUP_LOG_PATH/full_$BACKUP_DATE.log 

         

         if [ "${PIPESTATUS[0]}" -ne 0 ]; then

                        (echo "Subject: MySQL Backup Failed: MySQL Backup failed on `hostname`";

                   cat ${BACKUP_LOG_PATH}/incr_${BACKUP_DATE}.log;

                    ) | /usr/sbin/sendmail -O NoRecipientAction=add-to -f${MAIL_FROM} ${MAIL_TO}

            fi

  fi

  

 

}

 

 

 

case $1 in

 

       full)

          mysql_backup_check

          mysql_full_backup

          ;;

 

        incr)

          mysql_backup_check

          mysql_incr_backup

          ;;

 

         *)

          echo "full backup parameter missed!"

          echo "incr backup parameter missed!"

          ;;

esac    

然后根据备份策略设置crontab作业,例如如下所示

MySQL 使用XtraBackup的shell脚本介绍

-----------------------------------------------------------------分割线------------------------------------------------------------------------------

在使用这个脚本中,发现了一个小bug,没有定期清理增量备份的历史备份,修正后的脚本如下所示.

#!/bin/bash 

 

#################################################################################

#                                                                               #

# This script is used for MySQL daily backup. it is a package of Xtrabackup shell script      #

#                                                                                      #

# ################################################################################

#                                                                                #

# ScriptName            :    mysql_backup.sh                                     #

# Author                :    Kerry                                               #

# CerateDate            :    2016-04-24                                          #

# Blogs                 :    www.cnblogs.com/kerrycode                           #

# @author               :    kerry2008code@qq.com                                #

#********************************************************************************#

# Version        Modified Date            Description                            #

#********************************************************************************#

# V.1.0          2016-04-24     create the script for mysql daily backp          #


# V.1.1          2016-07-26     fix the bug increase backup did not rm the old backupset#

##################################################################################

 

 

 

BACKUP_DATE=$(date +%Y-%m-%d_%H_%M_%S)

BACKUP_DIR=/backup/mysql/mysql_db_backup

FULLBACKUP_PATH=$BACKUP_DIR/full

INCRBACKUP_PATH=$BACKUP_DIR/incr

BACKUP_LOG_PATH=$BACKUP_DIR/logs

BACKUP_KEEP_DAY=30

MYSQL_CONF=/usr/my.cnf

INNOBACKUPEX=/usr/bin/innobackupex

MYSQL_CMD=/usr/bin/mysql

MYSQL_CONNECT="--host=127.0.0.1 --user=root --password=xxx--port=3306"

MAIL_FROM="root@`hostname`"

MAIL_TO="xxx@xxxx.com"

MAIL_TO_ERROR="xxxx@xxxx.com"

 

error()

{

 echo "$1" 1>&2

 exit 1

}

 

#before the backup, check the system enviroment setting and mysql status and so on

mysql_backup_check()

{

 

    if [ ! -d $FULLBACKUP_PATH ];then

        mkdir -p $FULLBACKUP_PATH

    fi

    

    if [ ! -d $INCRBACKUP_PATH ];then

        mkdir -p $INCRBACKUP_PATH

    fi

    

    if [ ! -d $BACKUP_LOG_PATH ];then

        mkdir -p $BACKUP_LOG_PATH

    fi

    

    

    if [ ! -x $INNOBACKUPEX ];then

       error "$INNOBACKUPEX did not exists"

    fi

    

    if [ ! -x $MYSQL_CMD ];then

       error "mysql client did not exists!"

    fi

    

     mysql_status=`netstat -nl | awk 'NR>2{if ($4 ~ /.*:3306/) {print "Yes";exit 0}}'`  

      

        if [ "$mysql_status" != "Yes" ];then  

          error "MySQL did not start. please check it"  

        fi

   

        if ! `echo 'exit' | $MYSQL_CMD -s $MYSQL_CONNECT` ; then  

         error "please check the user and password is correct!"  

        fi  

}

 

 

xtra_backup()

{

  if [ $# = 2 ];then

        $INNOBACKUPEX --defaults-file=$MYSQL_CONF $MYSQL_CONNECT  --no-timestamp  $1/full_$BACKUP_DATE>$2 2>&1

  elif [ $# = 3 ];then

        $INNOBACKUPEX  --defaults-file=$MYSQL_CONF $MYSQL_CONNECT  --no-timestamp --incremental  $1/incr_$BACKUP_DATE  --incremental-basedir $2 >$3 2>&1

  else

      error "the parameter is not correct"

  fi

}

 

 

lastest_fullback_dir()

{

    if [ -d $1 ]; then

        path=`ls -t $1 |head -n 1`

        if [  $path ]; then

            echo $path

        else

            error "lastest_fullback_dir(): 目录为空,没有最新目录"

        fi

    else

        error "lastest_fullback_dir(): 目录不存在或者不是目录"

    fi

}

 

 

mysql_full_backup()

{

    xtra_backup  $FULLBACKUP_PATH $BACKUP_LOG_PATH/full_$BACKUP_DATE.log

    

    if [ "${PIPESTATUS[0]}" -ne 0 ]; then

        (echo "Subject: MySQL Backup Failed: MySQL Backup failed on `hostname`";

      cat ${BACKUP_LOG_PATH}/full_${BACKUP_DATE}.log;

    ) | /usr/sbin/sendmail -O NoRecipientAction=add-to -f${MAIL_FROM} ${MAIL_TO}

    else

      (echo "Subject: MySQL Backup Success: MySQL Backup Succeed on `hostname`";

      cat ${BACKUP_LOG_PATH}/full_${BACKUP_DATE}.log;

    ) | /usr/sbin/sendmail -O NoRecipientAction=add-to -f${MAIL_FROM} ${MAIL_TO}

    fi

 

    

    #cd $FULLBACKUP_PATH 

    

    #ls -t | tail -n +$BACKUP_KEEP_DAY | xargs rm -rf

    find ${FULLBACKUP_PATH}  -mtime +$BACKUP_KEEY_DAY -name "*" -exec rm -rf {} \;

}

 

mysql_incr_backup()

{

 

  LATEST_FULL_BACKUP=`find $FULLBACKUP_PATH -mindepth 1 -maxdepth 1 -type d -printf "%P\n" | sort -nr | head -1` 

  

  LATEST_FULL_BACKUP_TIME=`stat -c %Y $FULLBACKUP_PATH/$LATEST_FULL_BACKUP`

  

  if [ $LATEST_FULL_BACKUP ];then

        #不是第一次增量备份,以最新的增量备份目录为base_dir

        xtra_backup $INCRBACKUP_PATH  $FULLBACKUP_PATH/`lastest_fullback_dir $FULLBACKUP_PATH`  $BACKUP_LOG_PATH/incr_$BACKUP_DATE.log 

  else

        # the first incremental backup need do full backup first 

         xtra_backup $FULLBACKUP_PATH  $BACKUP_LOG_PATH/full_$BACKUP_DATE.log 

         

         if [ "${PIPESTATUS[0]}" -ne 0 ]; then

                        (echo "Subject: MySQL Backup Failed: MySQL Backup failed on `hostname`";

                   cat ${BACKUP_LOG_PATH}/incr_${BACKUP_DATE}.log;

                    ) | /usr/sbin/sendmail -O NoRecipientAction=add-to -f${MAIL_FROM} ${MAIL_TO}

            fi

  fi

  

  #cd ${INCRBACKUP_PATH}

  #ls -t | tail -n +$BACKUP_KEEP_DAY | xargs rm -rf

  find ${INCRBACKUP_PATH}  -mtime +$BACKUP_KEEY_DAY -name "*" -exec rm -rf {} \;

  

}

 

 

 

case $1 in

 

       full)

          mysql_backup_check

          mysql_full_backup

          ;;

 

        incr)

          mysql_backup_check


mysql_incr_backup

          ;;

 

         *)

          echo "full backup"

          echo "incr backup"

          ;;

esac    

MySQL 使用XtraBackup的shell脚本介绍的更多相关文章

  1. CentOS6.7下使用非root用户(普通用户)编译安装与配置mysql数据库并使用shell脚本定时任务方式实现mysql数据库服务随机自动启动

    CentOS6.7下使用非root用户(普通用户)编译安装与配置mysql数据库并使用shell脚本定时任务方式实现mysql数据库服务随机自动启动1.关于mysql?MySQL是一个关系型数据库管理 ...

  2. shell脚本介绍、shell脚本结构和执行、date命令用法、shell脚本中的变量

    7月11日任务 20.1 shell脚本介绍20.2 shell脚本结构和执行20.3 date命令用法20.4 shell脚本中的变量 20.1 shell脚本介绍 1.shell脚本语言是linu ...

  3. Linux centosVMware shell脚本介绍、shell脚本结构和执行、date命令用法、shell脚本中的变量

    一. shell脚本介绍 shell是一种脚本语言 aming_linux blog.lishiming.net 可以使用逻辑判断.循环等语法 可以自定义函数 shell是系统命令的集合 shell脚 ...

  4. 可以自动安装mysql数据库的一个shell脚本

    发布:thatboy   来源:脚本学堂     [大 中 小] 分享一例shell脚本,可以实现mysql数据库的自动安装,脚本写的不错,无论是用来学习,还是生产环境中应用,都是不错的,有需要的朋友 ...

  5. 一个备份MySQL数据库的简单Shell脚本(转)

    Shell脚本是我们写不同类型命令的一种脚本,这些命令在这一个文件中就可以执行.我们也可以逐一敲入命令手动执行.如果我们要使用shell脚本就必须在一开始把这些命令写到一个文本文件中,以后就可以随意反 ...

  6. [转]一个备份MySQL数据库的简单Shell脚本

    本文翻译自 iSystemAdmin 的 <A Simple Shell Script to Backup MySQL Database> Shell脚本是我们写不同类型命令的一种脚本,这 ...

  7. shell脚本介绍以及常用命令

    Shell脚本 Shell Script,Shell脚本与Windows/Dos下的批处理相似,也就是用各类命令预先放入到一个文件中,方便一次性执行的一个程序文件,主要是方便管理员进行设置或者管理用的 ...

  8. mysql自动备份维护shell脚本 &lpar;copy&rpar;

    #!/bin/bash #Mysql 自动备份 压缩并上传到 指定ftp #设想每天凌晨3点备份mysql #编辑crontab配置文件 # * * * backupmysql.sh #压缩并以&qu ...

  9. linux中备份mysql数据库的一个shell脚本

    #!/bin/bash #FileName:select_into_bak.sh #Desc:Use select into outfile to backup db or tables #Creat ...

随机推荐

  1. erlang日志功能。

    用cowboy这个库,没有日志功能,所以研究了otp提供的日志功能. 1.启动SASL的方式 erl –boot start_sasl 默认配置文件下启动SASL, {env, [{sasl_erro ...

  2. Swift版音乐播放器(简化版),swift音乐播放器

    这几天闲着也是闲着,学习一下Swift的,于是到开源社区Download了个OC版的音乐播放器,练练手,在这里发扬开源精神, 希望对大家有帮助! 这个DEMO里,使用到了 AudioPlayer(对音 ...

  3. for循环问题

    印象中的for语句是这样的,语法:  for (语句 1; 语句 2; 语句 3) { 被执行的代码块 }  语句 1 (代码块)开始前执行 starts. 语句 2 定义运行循环(代码块)的条件 语 ...

  4. git分支管理之创建与合并分支

    在版本回退里,你已经知道,每次提交,Git都把它们串成一条时间线,这条时间线就是一个分支.截止到目前,只有一条时间线,在Git里,这个分支叫主分支,即master分支.HEAD严格来说不是指向提交,而 ...

  5. PAT1013&colon; Battle Over Cities

    1013. Battle Over Cities (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue It ...

  6. 移动网站用backbone还是angular&quest;

    移动网站用backbone还是angular? 作者:戴嘉华链接:https://www.zhihu.com/question/21871888/answer/26130922来源:知乎著作权归作者所 ...

  7. vue eventBus 跳坑的办法

    前言(feihua): 最近闲来没事写了一个小的demo,在小的数据传输上没有必要去使用vuex,对于非父子组件的传值方法总结了一点心得体会供大家参考(如有太low,还请大神别喷俺) 先上官方文档: ...

  8. 项目Alpha冲刺(团队6&sol;10)

    项目Alpha冲刺(团队6/10) 团队名称: 云打印 作业要求: 项目Alpha冲刺(团队) 作业目标: 完成项目Alpha版本 团队队员 队员学号 队员姓名 个人博客地址 备注 221600412 ...

  9. Linux笔记 &num;09&num; Tomcat多开以及Nginx负载均衡简单例子

    索引 Tomcat怎样多开.. 1.添加环境变量(最基础.关键的步骤!) 2.改catalina.sh 3.改相关端口 Nginx负载均衡简单例子 Tomcat怎样多开.. 演示一下如何开两个(开n个 ...

  10. 3--Python入门--Python数据集合类型--元组

    在基础数据类型的基础上,Python有6中数据集合的类型: 列表list,最常用的数据类型,以[]为标识 元组tuple,和list很相似,但是不能二次赋值,用()标识 集合set,和list类似,但 ...