前言
这是在百度文库里看到的文章,原名叫做《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 将 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=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 "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=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 "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
数据库恢复:
完全备份文件的恢复
完全备份文件的格式为:20110301.sql
登录 MYSQL(mysql –uroot –proot)
use castor;
source /home/20110301.sql
增量备份文件的恢复
增量备份文件的格式为:daily20110302.sql
use castor;
source /home/ daily20110302.sql