I'm a tree and wating for the spring!
|

【转】MYSQL完全与增量备份

★作者:桐星豆博客   |  ★类别: MySQL   |  ★发布时间: 2015-05-20 09:39   |  ★更新时间: 2015-05-20 10:47   |  ★浏览次数:1521   |  ★ 评论(0)

一、文档介绍
本文档采用mysqldump 对数据库进行备份,mysqldump 是采用SQL级别的备份机制,它将数据表导成 SQL 脚本文件,在不同的 MySQL 版本之间升级时相对比较合适,这也是最常用的备份方法,mysqldump 比直接拷贝要慢些。
本文描述Mysql数据库的自动备份,包括完全备份和增量备份。其中,完全备份每周六执行一次,系统自动保存最近一个月的备份文件,增量备份每天都会执行,系统自动保存最近35天的备份文件。

 

二、备份策略布置
(1)、创建备份目录与文件
Shell> mkdir /srv/bakmysql
Shell> mkdir /srv/bakmysql/daily
Shell> touch /srv/bakmysql/mysqlbak.log

(2)、启用二进制日志
采用 binlog 的方法相对来说更灵活,省心省力,而且还可以支持增量备份。
启用 binlog 时必须要重启 mysqld。首先,关闭 mysqld,打开 /etc/my.cnf,加入以下几行:
[mysqld]
log-bin
然后启动 mysqld 就可以了。运行过程中会产生 HOSTNAME-bin.000001 以及 HOSTNAME-bin.index,前面的文件是 mysqld 记录所有对数据的更新操作,后面的文件则是所有 binlog 的索引,都不能轻易删除。关于 binlog 的更详细信息请查看手册。

 

(3)、设置crontab任务,每天执行备份脚本
shell> vi /etc/crontab 
添加以下:
#每个星期六凌晨1:00执行完全备份脚本
0 1 * * 6 root /usr/sbin/mysqlfullbak
#每天凌晨6:00做增量备份
0 6 * * * root /usr/sbin/mysqldailybak

 

(4)、使用SSH将mysqldailybak mysqlfullbak rmbackup三个文本内容放到系统/usr/sbin目录下相应的文件中,并且添加可执行权限,如:chmod +x rmbackup
完全备份脚本
#!/bin/bash
# Name:mysqlfullbak
# This is mysql mysqlfullbak scripts
# By song
# Last Modify:2011-02-23

#定义脚本存放路径
scriptsDir=/usr/sbin
#定义用户名及密码
user=root
userPWD=123456789
#定义要备份的数据库
database=castor
#定义完全备份文件存放路径
bakDir=/srv/bakmysql

eMailFile=$bakDir/email.txt
eMail=www@txdou.com
#定义日志文件
LogFile=$bakDir/mysqlbak.log

DATE=`date +%Y%m%d`
echo " " >> $LogFile
echo " " >> $LogFile
echo "--------------------------" >> $LogFile
echo $(date +"%y-%m-%d %H:%M:%S") >>$LogFile
echo "-----------------" >> $LogFile

cd $bakDir
DumpFile=$DATE.sql
#GZDumpFile=$DATE.sql.tgz
mysqldump --flush-logs -u$user -p$userPWD --quick $database >$DumpFile
echo "Dump Done" >> $LogFile
#tar cvzf $GZDumpFile $DumpFile >> $LogFile 2 >2&1
#echo "[$GZDumpFile]Backup Success!" >> $LogFile
echo  "[$DumpFile]Backup Success!" >> $LogFile

#Delete old backup files(mtime>2)
$scriptsDir/rmbackup

#Delete previous daily backup files:完整备份后,删除增量备份的文件,只保留最近35天的增量备份文件
daily_databakDir=$bakDir/daily
cd $bakDir/daily
find $daily_databakDir -name "daily*" -type f -mtime +35 -exec rm {} \; > /dev/null 2>&1

#发送邮件通知
#cat $eMailFile | mail -s "MySQL Backup" $eMail

 

增量备份脚本
#!/bin/bash
# Name:mysqldailybak
# This ia mysql mysqldailybak scripts
# By songdesong
# Last modify:2011-02-23
#定义用户名及密码
user=root
userPWD=123456789
#定义数据库
database=castor

/usr/bin/mysqladmin -u$user -p$userPWD flush-logs
daily_databakDir=/srv/bakmysql/daily
#定义MYSQL数据目录
mysqlDataDir=/srv/mysql/

eMailFile=$daily_databakDir/email.txt
eMail=www@txdou.com

DATE=`date +%Y%m%d`
logFile=$daily_databakDir/mysql$DATE.log
echo "       " > $eMailFile
echo "-----------------------" >> $eMailFile
echo $(date +"%y-%m-%d %H:%M:%S") >> $eMailFile
echo "-------------------------" >> $eMailFile
TIME=$(date "-d 10 day ago" +%Y%m%d%H%M%S)
StartTime=$(date "-d 1 day ago" +"%Y-%m-%d %H:%M:%S")
echo “Delete 10 days before the log” >>$eMailFile
mysql -u$user -p$userPWD -e "purge master logs before ${TIME}" && echo "delete 10 days before log" |tee -a $eMailFile #删除10天前的2进制文件

filename=`cat $mysqlDataDir/mysqld-bin.index |awk -F "/" '{print $2}'` # 2进制文件
for i in $filename
do
echo "$StartTime start backup binlog" >> $eMailFile
mysqlbinlog -u$user -p$userPWD -d $database --start-datetime="$StartTime" $mysqlDataDir/$i >> $daily_databakDir/daily$DATE.sql |tee -a $eMailFile
done
if [ $? = 0 ]
then

# 删除mtime>32的增量日志备份文件
find $daily_databakDir -name "*.log" -type f -mtime +32 -exec rm {} \; > /dev/null 2>&1

cd $daily_databakDir
#tar -cvzf $daily_databakDir/$database$DATE.tar.gz daily$DATE.sql >>/dev/null 2&1
#scp 至另一台服务器
echo "Daily backup succeed" >> $eMailFile
else
echo "Daily backup fail" >> $eMailFile
mail -s "MySQL Backup" $eMail < $eMailFile #备份失败之后发送邮件通知
fi
cat $eMailFile > $logFile


# 删除mtime>32的增量日志备份文件
find $daily_databakDir -name "*.log" -type f -mtime +32 -exec rm {} \; > /dev/null 2>&1

 

删除完全备份文件脚本
#!/bin/sh
# Name:rmBackup
# PS:Delete old Backup.
# By:song
# Last Modify:2011-02-17
#
# 定义备份目录
dataBackupDir=/srv/bakmysql
# 删除mtime>32的日志备份文件
find $dataBackupDir -name "*.sql" -type f -mtime +32 -exec rm {} \; > /dev/null 2>&1


三、数据库恢复
1、完全备份文件的恢复
完全备份文件的格式为:20110301.sql
登录MYSQL(mysql –uroot –p123456789)
use castor;
source  /home/20110301.sql

2、增量备份文件的恢复
增量备份文件的格式为:daily20110302.sql
use castor;
source /home/ daily20110302.sql

 

出处:mysql备份计划_百度文库 http://wenku.baidu.com/link?url=hHzw6USaNzVFfC14qsrVQklSMi1li_2fF7s6F_eVAa4IohX2PWD_ohIv5MRY3TuKmaZkPvb0cPgbuHIwnXP-xhqTBF0GXVOfhl1-LgnSg2C

请尊重他人的劳动果实,转载时务必注明出处! 请尊重他人的劳动果实,转载时务必注明出处!
转载请注明:文章转载自:桐星豆博客 [http://blog.txdou.com]
本文标题:【转】MYSQL完全与增量备份
本文地址:http://blog.txdou.com/article109
分享到QQ空间 分享到腾讯朋友

  • 注意:“桐星豆博客”只会以“回复”的身份出现,不会以“咨询”的身份出现在留言或评论中,凡是以“咨询”的身份出现的留言或评论均为他人盗用!
  • 本站用以回复网友评论的唯一名称是“桐星豆博客”,除此外均无效,网友不得用此名进行相应文章的评论或回复!
  • 用户言论只代表其个人观点,不代表桐星豆博客的观点或立场!
  • 非诚勿扰,请友好如实的评论,杜绝谩骂、人格攻击等一切伤人言论,请严格遵循中华人民共和国法律法规!
  • 桐星豆博客拥有最终解释权,如有网友违规,本站将有权删除或屏蔽违规评论,情节严重者账户加入黑名单、永久封IP并报司法部门严惩!
  • 您一旦参与评论本站则默认为您已经同意以上条款,否则“非诚勿扰”,谢谢合作!

您的姓名或昵称: 选填
您的E-Mail地址: ☆必填--仅站长可见
您个人网站地址: 选填 ( 如果填写,请务必加上 http:// 或 https:// 等等 )
留言内容:

验证码: 点击重新生成验证码  [ ctrl + enter ]

CopyRight © 2009-2020 by 桐星豆 All Rights Reserved. ICP证:京ICP备20021364号