MYSQL完全与增量备份及恢复

来源:互联网 发布:足球赛程安排软件 编辑:程序博客网 时间:2024/04/29 11:52

MYSQL完全与增量备份及恢复文档

文档介绍

本文档采用mysqldump 对数据库进行备份,mysqldump是采用SQL级别的备份机制,它将数据表导成 SQL 脚本文件,在不同的 MySQL 版本之间升级时相对比较合适,这也是最常用的备份方法,mysqldump比直接拷贝要慢些。

本文描述Mysql数据库的自动备份,包括完全备份和增量备份。其中,完全备份每周六执行一次,系统自动保存最近一个月的备份文件,增量备份每天都会执行,系统自动保存最近35天的备份文件。

 

 

备份策略布置

(1)、创建备份目录与文件

Shell> mkdir /srv/bakmysql

Shell> mkdir /srv/bakmysql/daily

Shell> touch /srv/bakmysql/mysqlbak.log

Shell>

(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将mysqldailybakmysqlfullbak rmbackup三个文本内容放到系统/usr/sbin目录下相应的文件中,并且添加可执行权限,如:chmod +x rmbackup

 

脚本内容

完全备份脚本

#!/bin/bash

#Name:mysqlfullbak

# This is mysqlmysqlfullbak scripts

# By song

# LastModify:2011-02-23

 

#定义脚本存放路径

scriptsDir=/usr/sbin

#定义用户名及密码

user=root

userPWD=123456789

#定义要备份的数据库

database=castor

#定义完全备份文件存放路径

bakDir=/srv/bakmysql

 

eMailFile=$bakDir/email.txt

eMail=sdesong@163.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 "DumpDone" >> $LogFile

#tar cvzf$GZDumpFile $DumpFile >> $LogFile 2 >2&1

#echo"[$GZDumpFile]Backup Success!" >> $LogFile

echo  "[$DumpFile]Backup Success!">> $LogFile

 

#Delete oldbackup files(mtime>2)

$scriptsDir/rmbackup

 

#Delete previousdaily 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$userPWDflush-logs

daily_databakDir=/srv/bakmysql/daily

#定义MYSQL数据目录

mysqlDataDir=/srv/mysql/

 

eMailFile=$daily_databakDir/email.txt

eMail=sdesong@163.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 "purgemaster logs before ${TIME}" && echo "delete 10 days beforelog" |tee -a $eMailFile #删除10天前的2进制文件

 

filename=`cat$mysqlDataDir/mysqld-bin.index |awk -F "/" '{print $2}'` # 2进制文件

for i in $filename

do

echo "$StartTime start backupbinlog" >> $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/null2&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

 

 

数据库恢复

完全备份文件的恢复

完全备份文件的格式为:20110301.sql

登录MYSQL(mysql –uroot –p123456789)

use castor;

source /home/20110301.sql

增量备份文件的恢复

增量备份文件的格式为:daily20110302.sql

use castor;

source /home/ daily20110302.sql

0 0