如需转载,请经本人同意。

这是之前写的一个备份脚本,调用的备份工具是xtrabackup

编写思路是:每周一全备份,备份后提取lSN号,对备份文件进行压缩,其余时候在LSN的基础上进行增量备份,并对30天外的备份数据进行清楚操作。该脚本对shell的基本语法都有覆盖,对快速入门shell会有帮助。

脚本语言:shell

#!/usr/bin/bash
# @author Jane.Hoo
# @written at://
# @GRANT SELECT, RELOAD, SUPER, LOCK TABLES, SHOW VIEW, EVENT ON *.* TO 'backupuser'@'localhost' IDENTIFIED BY 'xxxxxxxxx'
# MY_DAY=`date +%A`
MY_TIMESTAMP=`date +%Y%m%d`
MY_DATABASEDIR=/mysql/databackup/
BACKUPWORKSPACE=$MY_DATABASEDIR'BACKUPSPACE'$MY_TIMESTAMP
DUMPFILE='' USER=backupuser
PASSWORD=backuP_#
MYSQL_CONFIG=/etc/my.cnf
PARALLEL=
DATABASES='"zabbix mysql test"'
TOOL='/usr/local/xtrabackup/bin/innobackupex' LOGFILE=$MY_DATABASEDIR'LOG'$MY_TIMESTAMP
LSN=
LSN_PATH=$MY_DATABASEDIR'LSN-RECORD.TXT'
echo "">$LOGFILE
if [ ! -d $BACKUPWORKSPACE ];then
mkdir -p $BACKUPWORKSPACE
else
echo $BACKUPWORKSPACE" is exits. program exit"|tee -a $LOGFILE
exit
fi if [ $MY_DAY = 'Monday' ];then
echo "today is monday,ALL BACKUP "|tee -a $LOGFILE
command="$TOOL --defaults-file=$MYSQL_CONFIG --user=$USER --password=$PASSWORD --parallel=$PARALLEL --databases=$DATABASES --no-timestamp $BACKUPWORKSPACE 2>>$LOGFILE"
eval $command cd $BACKUPWORKSPACE
LSN=`cat xtrabackup_info |grep innodb_to_lsn|head -n |awk -F ' = ' '{print $2}'`
echo $LSN>$LSN_PATH
DUMPFILE='ALL_DUMPFILE'$MY_TIMESTAMP'.tar.gz'
cd $MY_DATABASEDIR
tar -zcvf $DUMPFILE 'BACKUPSPACE'$MY_TIMESTAMP >> $LOGFILE
if [ $? -ne ];then
echo "compress fail!."|tee -a $LOGFILE
exit
else
echo "compress ok."|tee -a $LOGFILE
fi
rm -rf $BACKUPWORKSPACE
if [ $? -ne ];then
echo "remove workspace fail!."|tee -a $LOGFILE
exit
else
echo "dump compeletly ok."|tee -a $LOGFILE
fi
else
echo "today is "$MY_DAY"increment backup ">>$LOGFILE
cd $MY_DATABASEDIR
LSN=`cat LSN-RECORD.TXT |head -n `
command="$TOOL --defaults-file=$MYSQL_CONFIG --user=$USER --password=$PASSWORD --parallel=$PARALLEL --databases=$DATABASES --incremental-lsn=$LSN --incremental --no-timestamp $BACKUPWORKSPACE 2>>$LOGFILE"
eval $command
cd $BACKUPWORKSPACE
LSN=`cat xtrabackup_info |grep innodb_to_lsn|head -n |awk -F ' = ' '{print $2}'`
echo $LSN>$LSN_PATH
DUMPFILE='ICR_DUMPFILE'$MY_TIMESTAMP'.tar.gz'
cd $MY_DATABASEDIR
tar -zcvf $DUMPFILE 'BACKUPSPACE'$MY_TIMESTAMP >> $LOGFILE
if [ $? -ne ];then
echo "compress fail!."|tee -a $LOGFILE
exit
else
echo "compress ok."|tee -a $LOGFILE
fi
rm -rf $BACKUPWORKSPACE
if [ $? -ne ];then
echo "remove workspace fail!."|tee -a $LOGFILE
exit
else
echo "dump compeletly ok."|tee -a $LOGFILE
fi
fi find $MY_DATABASEDIR -name "*.tar.gz" -type f -mtime + -exec rm {} \;>>$LOGFILE >&
find $MY_DATABASEDIR -name "LOG*" -type f -mtime + -exec rm {} \;>>$LOGFILE >&
作者:jane.hoo
出处:jane.hoo的博客 http://www.cnblogs.com/janehoo/
[人生不设限,生命不息,折腾不止]
您的支持是对博主最大的鼓励,感谢您的认真阅读。本文版权归作者所有,欢迎转载,但请保留该声明。
												

shell编写mysql备份工具的更多相关文章

  1. MySQL备份工具之mysqldump使用

    MySQL备份工具之mysqldump使用说明 一.备份分类 根据能否停用数据库,将备份类型分为: 1. 冷备:数据库服务停止后备份 2. 温备:只能对数据库进行读操作,不能进行写操作 3. 热备:在 ...

  2. mysql备份工具innobackupex,xtrabackup-2.1的原理和安装

    mysql备份工具innobackupex,xtrabackup-2.1的原理和安装 http://bbs.2cto.com/read.php?tid=310496 一.Xtrabackup介绍 1. ...

  3. Mysql备份工具xtraback全量和增量测试

    Mysql备份工具xtraback全量和增量测试   xtrabackup 是 percona 的一个开源项目,可以热备份innodb ,XtraDB,和MyISAM(会锁表) 官方网址http:// ...

  4. Mysql备份工具比较

    Mysql备份工具比较 大 | 中 | 小 [ 2012/12/25 12:10 | by Sonic ] 1. 使用automysqlbackup http://sourceforge.net/pr ...

  5. mysql备份工具 :mysqldump mydumper Xtrabackup 原理

    备份是数据安全的最后一道防线,对于任何数据丢失的场景,备份虽然不一定能恢复百分之百的数据(取决于备份周期),但至少能将损失降到最低.衡量备份恢复有两个重要的指标:恢复点目标(RPO)和恢复时间目标(R ...

  6. Mysql备份工具mysqldump和mysqlhotcopy

    (1).Mysql备份类型 1)按照备份时对数据库的影响分为 Hot backup(热备):也叫在线备份.指在数据库运行中直接备份,对正在运行的数据库没有任何影响. Cold backup(冷备):也 ...

  7. mysql二进制日志和mysql备份工具介绍以及日志恢复

    mysql备份: 三种备份方式 冷备:数据库停机,在进行备份 热备:lock table锁表,read   数据库只可以读不能写,在备份 温备:备份时数据库正常运行 备份类型:完整备份:全部备份,部分 ...

  8. Mysql备份工具Xtrabackup

    Xtrabackup是一个开源的免费的热备工具,在Xtrabackup包中主要有Xtrabackup和innobackupex两个工具.其中Xtrabackup只能备份InnoDB和XtraDB两种引 ...

  9. MySQL备份工具percona-xtrabackup安装

    1.安装xtrabackup的yum源 rpm -ivh https://www.percona.com/redir/downloads/percona-release/redhat/latest/p ...

随机推荐

  1. 发邮件 和 excel导出中文文件名

    /** * 发邮件 * @param email * @param subject * @param body * @throws UnsupportedEncodingException */ pu ...

  2. Linux驱动学习之什么是驱动?

    一.什么是驱动? 1: 驱动一词的字面意思 2: 物理上的驱动 3: 硬件中的驱动 4: linux内核驱动.软件层面上的驱动广义上是指:这一段代码操作了硬件去动,所以这一段代码就叫硬件的驱动程序. ...

  3. [原创.数据可视化系列之二]使用cesium三维地图展示美国全球军事基地分布

    基于浏览器的三维地图还算是一个比较高冷的东西,最主要的技术难点是如何在浏览器上 多快好省 的显示三维数据,很遗憾,还真的没有太好的的方案,只能说还有可行的方案. 很久之前用过skyline,使用CS居 ...

  4. centos编译安装apache

    1.安装工具和依赖包 yum install unzipyum -y install pcre-develyum groupinstall "Development Tools" ...

  5. Oracle 更新表(另一张表)

    Update a set(a.province,a.city)= (select province,city from b where b.mobile=a.mobile)

  6. Java abstract class 和 interface 的区别

    Java abstract class 和 interface 的区别 1. abstract class和interface是Java语言中对于抽象类定义进行支持的两种机制 2. 以Door的抽象概 ...

  7. 北邮oj 题

    题目描述 Every year,prince prepares a birthday gift for princess.The gift is a box,which is decorated wi ...

  8. 模仿win10样式,基于jquery的时间控件

    工作需要,写了一个基于jquery的时间控件,仿win10系统时间控件格式. 目前基本功能都有了,但时间格式只实现少数,但由于结构设计已经充分优化,填充起来非常容易. 这个控件相对网上其他的时间控件, ...

  9. Java基础---AWT

    流式布局FlowLayout package net.zyz; import java.awt.Button; import java.awt.FlowLayout; import java.awt. ...

  10. js获取get方式传递的参数

    String.prototype.GetValue= function(parm) { var reg = new RegExp("(^|&)"+ parm +" ...