shell编写mysql备份工具
如需转载,请经本人同意。
这是之前写的一个备份脚本,调用的备份工具是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备份工具的更多相关文章
- MySQL备份工具之mysqldump使用
MySQL备份工具之mysqldump使用说明 一.备份分类 根据能否停用数据库,将备份类型分为: 1. 冷备:数据库服务停止后备份 2. 温备:只能对数据库进行读操作,不能进行写操作 3. 热备:在 ...
- mysql备份工具innobackupex,xtrabackup-2.1的原理和安装
mysql备份工具innobackupex,xtrabackup-2.1的原理和安装 http://bbs.2cto.com/read.php?tid=310496 一.Xtrabackup介绍 1. ...
- Mysql备份工具xtraback全量和增量测试
Mysql备份工具xtraback全量和增量测试 xtrabackup 是 percona 的一个开源项目,可以热备份innodb ,XtraDB,和MyISAM(会锁表) 官方网址http:// ...
- Mysql备份工具比较
Mysql备份工具比较 大 | 中 | 小 [ 2012/12/25 12:10 | by Sonic ] 1. 使用automysqlbackup http://sourceforge.net/pr ...
- mysql备份工具 :mysqldump mydumper Xtrabackup 原理
备份是数据安全的最后一道防线,对于任何数据丢失的场景,备份虽然不一定能恢复百分之百的数据(取决于备份周期),但至少能将损失降到最低.衡量备份恢复有两个重要的指标:恢复点目标(RPO)和恢复时间目标(R ...
- Mysql备份工具mysqldump和mysqlhotcopy
(1).Mysql备份类型 1)按照备份时对数据库的影响分为 Hot backup(热备):也叫在线备份.指在数据库运行中直接备份,对正在运行的数据库没有任何影响. Cold backup(冷备):也 ...
- mysql二进制日志和mysql备份工具介绍以及日志恢复
mysql备份: 三种备份方式 冷备:数据库停机,在进行备份 热备:lock table锁表,read 数据库只可以读不能写,在备份 温备:备份时数据库正常运行 备份类型:完整备份:全部备份,部分 ...
- Mysql备份工具Xtrabackup
Xtrabackup是一个开源的免费的热备工具,在Xtrabackup包中主要有Xtrabackup和innobackupex两个工具.其中Xtrabackup只能备份InnoDB和XtraDB两种引 ...
- MySQL备份工具percona-xtrabackup安装
1.安装xtrabackup的yum源 rpm -ivh https://www.percona.com/redir/downloads/percona-release/redhat/latest/p ...
随机推荐
- leetCode 354. Russian Doll Envelopes
You have a number of envelopes with widths and heights given as a pair of integers (w, h). One envel ...
- VSS记住用户名和密码
计算机-属性-高级系统设置-环境变量 新建两个环境变量如下: SSUSER(VSS的用户名) SSPWD(VSS的密码)
- visual c++ 2010安装失败导致CRM2015安装失败
记录一下: 今天重新安装CRM2015时碰到以下错误: 安装一个或多个缺少的必备组件失败...,查看日志发现是 Microsoft Visual C++ 运行时 的安装失败,但查看系统发现vc++20 ...
- Quartz2D 画大白
今天初始Quartz2D,我好激动啊,也好开心,莫名的会喜欢带有图形相关的课程…… 好啦,闲话少说,今天用Quartz2D方法画了最最爱的大白.迫不及待的想要和大家分享. 1.首先实例化了view 2 ...
- spring的helloworld
前两天接到了支付宝的电话面试,问了我好多java中的知识,知识姐不看java好多年,这猛一问知道的东西还真是不少啊.趁着现在精力还算是比较旺盛,再把spring重新理一理,为下一次面试做准备. 学习每 ...
- Android菜鸟成长记12 -- ORMLite的简单使用
在我们的开发中,为了提高开发效率,我们一般都会使用到框架,ormilte则是我们必不可少的数据库框架. 对于ORMLite我也是今天才刚刚接触,我们先从一个简单的项目来了解它吧. ORMLite ja ...
- ListView下拉刷新
本内容为复制代码: 一.自定义ListView控件: package com.xczl.smart.view; import java.util.Date; import com.suliang.R; ...
- 如何进入IT行业?
其实IT行业就如一个具有标准配件的机一样是开放的行业,无论你是否科班出身,无论你是什么学历,只要你掌握相关的针对性很强的计算机知识,想在IT行业发展随时可以即插即用,这主要由IT行业的特点确PC定的. ...
- linux 程序管理与SElinux
此文涉及的命令:&.jobs.fg.bg.kill.nohup.ps.top.pstree.free.uname.uptime.netstat.dmesg.vmstat.fuser.lsof. ...
- jq 部分用法
这几天一直在写前台,因为jq是在客服端处理数据的,所以公司,一般都用这种方法,下面是我这几天用到的一些东西 1.修改table表格的第一轮显示值 function changeTableRowValu ...