MySQL 使用XtraBackup的shell脚本介绍
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作业,例如如下所示

-----------------------------------------------------------------分割线------------------------------------------------------------------------------
在使用这个脚本中,发现了一个小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脚本介绍的更多相关文章
- CentOS6.7下使用非root用户(普通用户)编译安装与配置mysql数据库并使用shell脚本定时任务方式实现mysql数据库服务随机自动启动
CentOS6.7下使用非root用户(普通用户)编译安装与配置mysql数据库并使用shell脚本定时任务方式实现mysql数据库服务随机自动启动1.关于mysql?MySQL是一个关系型数据库管理 ...
- shell脚本介绍、shell脚本结构和执行、date命令用法、shell脚本中的变量
7月11日任务 20.1 shell脚本介绍20.2 shell脚本结构和执行20.3 date命令用法20.4 shell脚本中的变量 20.1 shell脚本介绍 1.shell脚本语言是linu ...
- Linux centosVMware shell脚本介绍、shell脚本结构和执行、date命令用法、shell脚本中的变量
一. shell脚本介绍 shell是一种脚本语言 aming_linux blog.lishiming.net 可以使用逻辑判断.循环等语法 可以自定义函数 shell是系统命令的集合 shell脚 ...
- 可以自动安装mysql数据库的一个shell脚本
发布:thatboy 来源:脚本学堂 [大 中 小] 分享一例shell脚本,可以实现mysql数据库的自动安装,脚本写的不错,无论是用来学习,还是生产环境中应用,都是不错的,有需要的朋友 ...
- 一个备份MySQL数据库的简单Shell脚本(转)
Shell脚本是我们写不同类型命令的一种脚本,这些命令在这一个文件中就可以执行.我们也可以逐一敲入命令手动执行.如果我们要使用shell脚本就必须在一开始把这些命令写到一个文本文件中,以后就可以随意反 ...
- [转]一个备份MySQL数据库的简单Shell脚本
本文翻译自 iSystemAdmin 的 <A Simple Shell Script to Backup MySQL Database> Shell脚本是我们写不同类型命令的一种脚本,这 ...
- shell脚本介绍以及常用命令
Shell脚本 Shell Script,Shell脚本与Windows/Dos下的批处理相似,也就是用各类命令预先放入到一个文件中,方便一次性执行的一个程序文件,主要是方便管理员进行设置或者管理用的 ...
- mysql自动备份维护shell脚本 (copy)
#!/bin/bash #Mysql 自动备份 压缩并上传到 指定ftp #设想每天凌晨3点备份mysql #编辑crontab配置文件 # * * * backupmysql.sh #压缩并以&qu ...
- linux中备份mysql数据库的一个shell脚本
#!/bin/bash #FileName:select_into_bak.sh #Desc:Use select into outfile to backup db or tables #Creat ...
随机推荐
- 数据结构:C_链表队列的实现
数据结构链表形式队列的实现(C语言版) 1.写在前面 队列是一种和栈相反的,遵循先进先出原则的线性表. 本代码是严蔚敏教授的数据结构书上面的伪代码的C语言实现代码. 分解代码没有包含在内的代码如下: ...
- ZOJ Problem Set - 1001 A + B Problem
ZOJ ACM题集,编译环境VC6.0 #include <stdio.h> int main() { int a,b; while(scanf("%d%d",& ...
- 用纯JS做俄罗斯方块 - 简要思路介绍(1)
大家都知道俄罗斯方块是一款大众化的游戏了,我很小的时候就玩过,今年已经25岁了,可以说俄罗斯方块确实是历史悠久,做俄罗斯方块是我上个星期开始的想法.也许是由于自己从来没有写过这种东西吧,所以有生疏.代 ...
- TCP滑动窗口机制
我们可以大概看一下上图的模型: 首先是AB之间三次握手建立TCP连接.在报文的交互过程中,A将自己的缓冲区大小(窗口大小)3发送给B,B同理,这样双方就知道了对端的窗口大小. A开始发送数据,A连续发 ...
- iOS的一些面试题分析总结(1)
本篇主要说一下多线程的东西,因为东西比较多,所以直接拿出一整个篇幅来说它了. 3. 多线程的底层实现? 1.先说一下什么是进程,什么是线程.什么是多线程. 进程是资源分配的单位,线程是调度运行的基本单 ...
- 【翻译】设计模式学习系列1---【Design Patterns Simplified: Part 1【设计模式简述:第一部分】】
原文链接:http://www.c-sharpcorner.com/UploadFile/19b1bd/design-patterns-simplified-part1/ Design Pattern ...
- asp.net留言板项目源代码下载
HoverTree是一个asp.net开源项目,实现了留言板功能. 前台体验网址:http://hovertree.com/guestbook/ 后台请下载源代码安装. 默认用户名:keleyi 默认 ...
- Sql数据库查询当前环境有无死锁
DECLARE @spid INT , @bl INT , @intTransactionCountOnEntry INT , @intRowcount INT , @intCountProperti ...
- IIS实现反向代理
http://www.cnblogs.com/dreamer-fish/p/3911953.html C#实现: C#写的一个反向代理,可以缓存 https://www.oschina.net/cod ...
- iOS阶段学习第35天笔记(Touch手势介绍)
一.Touch手势 1.利用手势实现UIButton移动效果 实例代码 1) 创建一个继承自UIButton的类 MyButton.h 代码实现 #import <UIKit/UIKit.h ...