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

这是之前写的一个备份脚本,调用的备份工具是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/
[人生不设限,生命不息,折腾不止]
您的支持是对博主最大的鼓励,感谢您的认真阅读。本文版权归作者所有,欢迎转载,但请保留该声明。
												

最新文章

  1. TFS源代码管理的8大注意事项
  2. @SuppressWarnings的使用、作用、用法
  3. python 字符串复制
  4. LGLProgressHUD
  5. Heritrix源码分析(一) 包介绍(转)
  6. 8.11-8.16:usaco
  7. 学习笔记 css3--选择器&新增颜色模式&文本相关
  8. js获取input file完整路径的方法
  9. UVa1339 Ancient Cipher
  10. 关于java.lang.reflect.InvocationTargetException(jar 包缺少或者冲突)的错误
  11. Intellij-创建Maven项目速度慢
  12. Intent里ACTION的CALL和DIAL的区别?
  13. 更换Appsecrect应该要注意的问题
  14. 【HDU 6036】Division Game (NTT+数学)
  15. Quartz在Spring中动态设置cronExpression
  16. android sqlite select count
  17. 11 tensorflow在tf.while_loop循环(非一般循环)中使用操纵变量该怎么做
  18. 中国城市线划分—Where do you want to develop......
  19. python学习——练习题(8)
  20. oracle安装注意

热门文章

  1. TMS320DM642启动模式(Bootmode)(转)
  2. EBS 消息总线
  3. dma驱动
  4. 查linux端口连接情况用命令netstat
  5. Angularjs学习笔记(一)
  6. oracle 正则表达式
  7. funny_python 01 import antigravity
  8. Python“Non-ASCII character 'xe5' in file”报错问题(转)
  9. Python3利用BeautifulSoup4抓取站点小说全文的代码
  10. Sublime Text3 (转) 配置 以及快捷键配置