博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
svn 备份脚本(包含mysql数据库)
阅读量:6912 次
发布时间:2019-06-27

本文共 3150 字,大约阅读时间需要 10 分钟。

svn 备份脚本(包含mysql数据库)

备份svn 数据,分两个脚本

svn_data.sh 用于备份svn 数据到,远程rsync 服务器

mysql_bak.sh 用于备份mysql 数据库到,远程rsync 服务器

 

cat /root/sh/svn_data.sh

 
  1. #!/bin/bash 
  2. #backup /u01/svndata/ 
  3. #20110909 by dongnan 
  4.  
  5. #variables 
  6. rsync=/usr/bin/rsync 
  7. rsync_add=192.168.57.82 
  8. svn_data_dir=/u01/svndata 
  9. mysql_data_dir=/data/mysql 
  10. l_time=`date +'%Y-%m-%d %H:%M:%S'` 
  11. today_time=`date +'%Y-%m-%d'` 
  12. log_dir=/root/sh/log 
  13.  
  14.  
  15. #add for backup mysql  
  16. /root/sh/mysql_bak.sh || echo "$l_time mysql backup error!" >> /root/sh/log/mysql_bak.err 
  17. sleep 30 
  18.  
  19. #rsync 
  20. for var in $svn_data_dir $mysql_data_dir ;do 
  21. #echo $var && continue 
  22. now_time=`date +"%F_%T"` 
  23. if ! $rsync -avz --delete --password-file=/root/sh/pw "$var" dongnan@${rsync_add}::svn_data/ 2>>$log_dir/svn_err.txt;then 
  24.     echo $now_time >> $log_dir/svn_err.txt 
  25.     echo "#####" >> $log_dir/svn_err.txt 
  26. fi 
  27. done 
 
cat /root/sh/mysql_bak.sh
 
 
  1. #!/bin/bash 
  2. #backup mysql data 
  3. #20111012 by dongnan 
  4.  
  5. #variables 
  6. dump=/usr/bin/mysqldump 
  7. mysql=/usr/local/bin/mysql 
  8. option='-uroot -pdongnan --opt -e -x --master-data=2' 
  9. databases=$(mysql -uroot -ppassword -e 'show databases;' | awk '$1 !~ /Database|information_schema|test/ {print $1}') 
  10. bak_dir=/data/ 
  11. l_time=`date +'%Y-%m-%d %H:%M:%S'` 
  12. now_time=`date +'%Y-%m-%d'` 
  13. expires_time=`date +"%Y%m%d" --date='4 days ago'
  14. log=/root/sh/log/mysql_bak.err 
  15. date_dir=$(date +'%Y%m%d') 
  16.  
  17. #delete old file (4days)  
  18. find "$bak_dir" -name "${expires_time}" -type d | xargs rm -rf 
  19.  
  20. #date dir 
  21. test -e ${bak_dir}${date_dir} || mkdir -p ${bak_dir}${date_dir} 
  22.  
  23. #backup and gzip database.sql 
  24. for database in $databases;do 
  25.    $dump $option $database | gzip > ${bak_dir}${date_dir}/${now_time}-${database}.sql.gz || echo "$l_time $database backup error!!" >> $log 
  26. done 
 
 
结束

更多欢迎到此讨论:

37275208 

#update 20120605

gzip -dc 2012-06-01-uspace_uchome.sql.gz | mysql -uroot -pdongnan uspace_uchome

 

#update 20130210

 
  1. cat mysql_bak.sh 
  2. #!/bin/bash  
  3. #backup mysql data  
  4. #20111012 by dongnan  
  5.             
  6. #variables  
  7. dump=/usr/local/mysql/bin/mysqldump 
  8. mysql=/usr/local/mysql/bin/mysql 
  9. uuencode=/usr/bin/uuencode 
  10. email=dongnan@mail.com 
  11. option='-udongnan -pdongnan --opt -e -x --master-data=2' 
  12. databases=$($mysql -udongnan -pdongnan -e 'show databases;' | awk '$1 !~ /Database|information_schema|test|mysql/ {print $1}')  
  13. bak_dir=/backup/ 
  14. l_time=`date +'%Y-%m-%d %H:%M:%S'`  
  15. now_time=`date +'%Y-%m-%d'`  
  16. expires_time=`date +"%Y%m%d" --date='7 days ago'`  
  17. log=/root/sh/log/mysql_bak.err  
  18. date_dir=$(date +'%Y%m%d')  
  19.             
  20. #test command 
  21. for command in $dump $mysql $uuencode;do 
  22.     if [[ ! -e $command ]];then 
  23.         echo "Not Found $command" 
  24.         exit 1 
  25.     fi 
  26. done 
  27.        
  28. #delete old file (7days)   
  29. find "$bak_dir" -name "${expires_time}" -type d | xargs rm -rf  
  30.             
  31. #date dir  
  32. test -e ${bak_dir}${date_dir} || mkdir -p ${bak_dir}${date_dir}  
  33.             
  34. #backup and gzip database.sql  
  35. for database in $databases;do 
  36.     ! test -e ${bak_dir}${date_dir}/${now_time}-${database}.sql.gz || break 
  37.     $dump $option $database | gzip > ${bak_dir}${date_dir}/${now_time}-${database}.sql.gz || echo "$l_time $database backup error!!" >> $log  
  38.     $uuencode ${bak_dir}${date_dir}/${now_time}-${database}.sql.gz ${now_time}-${database}.sql.gz | mail  -s "${now_time}-${database}.sql.gz" $email 
  39. done 

#

本文转自 dongnan 51CTO博客,原文链接:http://blog.51cto.com/dngood/883480

转载地址:http://icbcl.baihongyu.com/

你可能感兴趣的文章
企业营业执照OCR识别
查看>>
给图片加水印
查看>>
我的友情链接
查看>>
AIX系统中适用于ksh的循环语句
查看>>
Nginx 配置详解
查看>>
什么是ARP攻击及ARP欺骗的种类
查看>>
MAC 安装cocoapods 遇到问题
查看>>
abstract class和interface有什么区别?
查看>>
OneNMP路由器、交换机监控
查看>>
软件生命周期
查看>>
解决:安装Jenkins时web界面出现jenkins实例似乎已离线问题
查看>>
解决phpMyAdmin在nginx+php-fpm模式下无法使用的问题
查看>>
自动领豆golang版
查看>>
EditText 只能输入数字字母
查看>>
vue中的条件渲染
查看>>
lnmp搭建
查看>>
菜鸟学Linux 第063篇笔记 postfix+mysql+courier-authlib
查看>>
【 58沈剑 架构师之路】InnoDB七种锁——共享/排它锁、意向锁、插入意向锁
查看>>
终究未能留下,秦致被动离去,汽车之家已变天
查看>>
wxWidgets第一课 wx/wx.h解决头文件包含问题
查看>>