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

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:
+关注继续查看

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

恢复mysql

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

恢复binlog中的sql 语句

 

#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


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
13天前
|
SQL 缓存 关系型数据库
MYSQL增量备份和全量备份脚本
MYSQL增量备份和全量备份脚本
|
14天前
|
SQL 关系型数据库 MySQL
MySql数据库中的视图,索引与数据库sql脚本如何导入与导出---(详细介绍)
MySql数据库中的视图,索引与数据库sql脚本如何导入与导出---(详细介绍)
212 0
|
27天前
|
存储 运维 安全
百度搜索:蓝易云【【运维】mysql与mongo的自动备份脚本】
请注意,确保在脚本中提供正确的数据库凭据,并将备份文件保存到足够的磁盘空间。此外,建议将备份文件定期迁移到安全的存储位置,以防止数据丢失或损坏。
201 2
|
1月前
|
关系型数据库 MySQL Linux
Linux下超简单的Mysql自动备份+定期删除之前备份文件脚本
Linux下超简单的Mysql自动备份+定期删除之前备份文件脚本
|
1月前
|
存储 SQL 关系型数据库
【MYSQL高级】数据生成与插入脚本编写与使用
【MYSQL高级】数据生成与插入脚本编写与使用
40 1
|
2月前
|
SQL 关系型数据库 MySQL
flask中生成迁移脚本并将orm模型映射至MySQL
flask中生成迁移脚本并将orm模型映射至MySQL
|
2月前
|
监控 关系型数据库 Shell
用shell脚本编写一个监控rds数据库外发到钉钉群的脚本
用shell脚本编写一个监控rds数据库外发到钉钉群的脚本
64 1
|
3月前
|
存储 SQL 关系型数据库
【MySQL】探索MySQL存储过程的魔力,初学者的数据库编程秘笈(内含实战SQL脚本)下
【MySQL】探索MySQL存储过程的魔力,初学者的数据库编程秘笈(内含实战SQL脚本)
113 1
|
3月前
|
存储 SQL 关系型数据库
【MySQL】探索MySQL存储过程的魔力,初学者的数据库编程秘笈(内含实战SQL脚本)上
【MySQL】探索MySQL存储过程的魔力,初学者的数据库编程秘笈(内含实战SQL脚本)
49 2
|
3月前
|
运维 监控 关系型数据库
【运维知识进阶篇】zabbix5.0稳定版详解4(用脚本自定义监控项+监控MySQL状态信息)(二)
【运维知识进阶篇】zabbix5.0稳定版详解4(用脚本自定义监控项+监控MySQL状态信息)(二)
44 0
推荐文章
更多