在数据库表丢失或损坏的情况下,备份你的数据库是很重要的。如果发生系统崩溃,你肯定想能够将你的表尽可能丢失最少的数据恢复到崩溃发生时的状态。本文主要对MyISAM表做备份恢复。
备份策略一:直接拷贝数据库文件
备份策略二:使用mysqldump备份数据库(一个星期全备一次,每天增量备份)
一、直接拷贝数据文件直接拷贝数据文件最为直接、快速、方便,但缺点是基本上不能实现增量备份。为了保证数据的一致性,需要在备份文件前,执行以下SQL语句:FLUSHTABLESWITHREADLOCK;也就是把内存中的数据都刷新到磁盘中,同时锁定数据表,以保证拷贝过程中不会有新的数据写入。这种方法备份出来的数据恢复也很简单,直接拷贝回原来的数据库目录下即可。为了方便的拷贝出数据文件,我写了一个脚本让其每天运行一次做备份。在/目录下建一个目录用来放置脚本文件,#mkdir/scripts
创建一个备份数据库的一个脚本文件
保存退出并添加可执行的权限
#chmod755backup_mysql.sh
让脚本每天执行一次,每天备份一次数据库,在crontab里面添加一行
Crontab�Ce
104***/scripts/backup_mysql.sh#每天4点10分运行脚本备份数据库
还原数据库的时候只要把备份出的文件拷贝到数据库放置数据的目录下,修改权限。重启下数据库就完成了恢复了。 二、使用mysqldump备份数据库mysqldump是采用SQL级别的备份机制,它将数据表导成SQL脚本文件,在不同的MySQL版本之间升级时相对比较合适,这也是最常用的备份方法。关于mysqldump的更详细解释用/MysqlDir/bin/mysqldump�Chelp来查看详细的解释。
我们使用的数据库备份完成之后有10个G如果每天都做一次全备,不方便,就一个星期做一次全备,一天做一次增量备份。为了不影响线上业务,实现在线备份,并且能增量备份,最好的办法就是采用主从复制机制(replication),在slave机器上做备份。详细的mysqlreplication请参看 mysql主主、主从复制详解一个星期一次的全备的脚本,脚本文件放在/scripts目录下,备份时需要一些目录,注意需要手动创建。#vimysql_full_bak.sh
#!/bin/bash
#Thisismysqlmysqlfullbakscripts
#2009-08-20
#badboy
user=bak
passwd=123456
databak_dir=/backup/cacti#备份的目录
eMailFile=$databak_dir/email.txt
DATE=`date+%Y%m%d`
logFile=$databak_dir/logs/mysql$DATE.log
database=cacti
echo"">$eMailFile
echo"---------------------------------">>$eMailFile
echo$(date+"%y-%m-%d%H:%M:%S")>>$eMailFile
cd/data
dumpFile=$database$DATE.sql
GZDumpFile=$database$DATE.tar.gz
options="-u$user-p$passwd--opt--extended-insert=false--triggers=false-R--hex-blob--flush-logs--delete-master-logs-B$database"
mysqldump$options>$dumpFile#导出数据文件
if[[$?==0]];then
tarcvzf$GZDumpFile$dumpFile>>$eMailFile2>&1
echo"BackupFileName:$GZDumpFile">>$eMailFile
echo"DataBaseBackupSuccess">>$eMailFile
scp$GZDumpFile地址”:/Dir#传送备份文件到另一台计算机,需要做好ssh信任
rm-f$dumpFile#删除备份的文件
rm�Crf$databak_dir/daily/*#删除每天备份的文件
else
echo"DataBaseBackupFail!">>$emailFile
mail-s"DataBaseBackupFail"$eMail<$eMailFile#如果备份不成功发送邮件通知
fi
echo"--------------------------------------------------------">>$logFile
cat$eMailFile>>$logFile更多mysqldump的选项请查看mysqldump�Chelp每天增量备份的脚本,定义为每天4点10分时运行此文件,备份上一天4点10分之后到今天4点之前的数据
#vimysqldailybak.sh
#!/bin/bash
#Thisismysqlmysqldailybakscripts
#2009-08-20
#badboy
/usr/bin/mysqladminflush-logs#
user=bak
passwd=123456
database=cacti
daily_databak_dir=$databak_dir/daily#备份目录,需要创建
eMailFile=$daily_databak_dir/email.txt
DATE=`date+%Y%m%d`
logFile=$daily_databak_dir/mysql$DATE.log
echo"">$eMailFile
echo"---------------------------------">>$eMailFile
echo$(date+"%y-%m-%d%H:%M:%S")>>$eMailFile
echo"---------------------------------">>$eMailFile
TIME=$(date"-d10dayago"+%Y%m%d%H%M%S)
StartTime=$(date"-d1dayago"+"%Y-%m-%d%H:%M:%S")
echo“Delete10daysbeforethelog”>>$eMailFile
mysql-u$user-p"$passwd"-e"purgemasterlogsbefore${TIME}"&&echo"delete10daysbeforelog"|tee-a$eMailFile#删除10天前的2进制文件
filename=/data/`cat/data/mysql-bin.index|awk-F"/"'{print$2}'`#2进制文件
foriin$filename
do
echo"$StartTimestartbackupbinlog">>$eMailFile
mysqlbinlog-u$user-p$passwd-d$batabase--start-datetime="$StartTime"$i>>$daily_databak_dir/daily$DATE|tee-a$eMailFile
done
if[$?=0]
then
cd$daily_databak_dir
tar-zcvf$daily_databak_dir/$database$DATE.tar.gzdaily$DATE>>/dev/null2>&1
#scp$daily_databak_dir/$database$DATE.tar.gz地址”:/Dir#传送备份文件到另一台计算机,需要做好ssh信任
echo"dailybackupsucceed">>$eMailFile
else
echo"dailybackupfail">>$eMailFile
mail-s"MySQLBackup"$eMail<$eMailFile#备份失败之后发送邮件通知
fi
cat$eMailFile>$logFile
添加可执行的权限
#chmod755/scripts/mysql_full_bak.sh/scripts/mysqldailybak.sh加到crontab里面让脚本自动执行,如果有专门用于备份的服务器,可以利用ssh认证、scp命令,自动发送到另一台服务器上,保证数据的安全。可以参看 rsync参数详解、利用ssh、rsync实现数据的定时同步#su�Cbak#crontab�Ce104**1-6/scripts/mysqldailybak.sh#礼拜一到礼拜六运行每天备份脚本
104**0/scripts/mysql_full_bak.sh#礼拜天执行全备份的脚本如果想把备份之后的数据文件,传送到另一台服务器上,做好ssh信任之后把脚本中红色的哪行注释去掉就行。需要更多scp的资料请查看scp--help本人对shell也不是很懂,如果里面有错误的地方,希望指正。谢谢#vibackup_mysql.sh#!/bin/bashbackup_dir=/backup/databak#备份文件放置目录
backup_target_dir=/backup/db
backup_logs_dir=/backup/logs#备份日志目录
db=bcmediaDATE=$(date+%Y%m%d)
#得到10天前的日期
ccDATE=$(date"-d10dayago"+%Y%m%d)echo"开始复制数据表">>$backup_logs_dir/$db$DATE
echo"-----------`date+"%Y-%m-%d%H:%M:%S"`--------------------">>$backup_logs_dir/$db$DATEcp-R/data/$db$backup_target_dir/#mysql数据库的数据目录为/dataecho"开始压缩数据表">>$backup_logs_dir/$db$DATE
echo"------------------------">>$backup_logs_dir/$db$DATEcd$backup_target_dirtar-zcvf$backup_dir/db$DATE.tar.gz$db/>>$backup_logs_dir/$db$DATEif[$?-eq0]
then
echo"backupsucceed">>$backup_logs_dir/$db$DATE
else
echo"backupfail">>$backup_logs_dir/$db$DATE
fiecho"开始删除原数据表">>$backup_logs_dir/$db$DATEecho"-----------------------">>$backup_logs_dir/$db$DATErm-rf$backup_target_dir/*&&echo“删除原数据表”>>$backup_logs_dir/$db$DATEecho"删除10天前数据">>$backup_logs_dir/$db$DATEif[-e$backup_dir/db$ccDATE.tar.gz]
then
rm-rf$backup_dir/db$ccDATE.tar.gz
echo"Delete$backup_dir/db$ccDATE.tar.gzsucceed">>$backup_logs_dir/$db$DATE
else
echo"Notfound$backup_dir/db$ccDATE.tar.gzfile">>$backup_logs_dir/$db$DATE
fi
if[-e$backup_logs_dir/$db$ccDATE]
then
rm-rf$backup_logs_dir/$db$ccDATE
echo"Delete$backup_logs_dir/$db$ccDATEsucceed">>$backup_logs_dir/$db$DATE
else
echo"Notfound$backup_logs_dir/$db$ccDATEfile">>$backup_logs_dir/$db$DATEfi
备份策略二:使用mysqldump备份数据库(一个星期全备一次,每天增量备份)
一、直接拷贝数据文件直接拷贝数据文件最为直接、快速、方便,但缺点是基本上不能实现增量备份。为了保证数据的一致性,需要在备份文件前,执行以下SQL语句:FLUSHTABLESWITHREADLOCK;也就是把内存中的数据都刷新到磁盘中,同时锁定数据表,以保证拷贝过程中不会有新的数据写入。这种方法备份出来的数据恢复也很简单,直接拷贝回原来的数据库目录下即可。为了方便的拷贝出数据文件,我写了一个脚本让其每天运行一次做备份。在/目录下建一个目录用来放置脚本文件,#mkdir/scripts
创建一个备份数据库的一个脚本文件
保存退出并添加可执行的权限
#chmod755backup_mysql.sh
让脚本每天执行一次,每天备份一次数据库,在crontab里面添加一行
Crontab�Ce
104***/scripts/backup_mysql.sh#每天4点10分运行脚本备份数据库
还原数据库的时候只要把备份出的文件拷贝到数据库放置数据的目录下,修改权限。重启下数据库就完成了恢复了。 二、使用mysqldump备份数据库mysqldump是采用SQL级别的备份机制,它将数据表导成SQL脚本文件,在不同的MySQL版本之间升级时相对比较合适,这也是最常用的备份方法。关于mysqldump的更详细解释用/MysqlDir/bin/mysqldump�Chelp来查看详细的解释。
我们使用的数据库备份完成之后有10个G如果每天都做一次全备,不方便,就一个星期做一次全备,一天做一次增量备份。为了不影响线上业务,实现在线备份,并且能增量备份,最好的办法就是采用主从复制机制(replication),在slave机器上做备份。详细的mysqlreplication请参看 mysql主主、主从复制详解一个星期一次的全备的脚本,脚本文件放在/scripts目录下,备份时需要一些目录,注意需要手动创建。#vimysql_full_bak.sh
#!/bin/bash
#Thisismysqlmysqlfullbakscripts
#2009-08-20
#badboy
user=bak
passwd=123456
databak_dir=/backup/cacti#备份的目录
eMailFile=$databak_dir/email.txt
DATE=`date+%Y%m%d`
logFile=$databak_dir/logs/mysql$DATE.log
database=cacti
echo"">$eMailFile
echo"---------------------------------">>$eMailFile
echo$(date+"%y-%m-%d%H:%M:%S")>>$eMailFile
cd/data
dumpFile=$database$DATE.sql
GZDumpFile=$database$DATE.tar.gz
options="-u$user-p$passwd--opt--extended-insert=false--triggers=false-R--hex-blob--flush-logs--delete-master-logs-B$database"
mysqldump$options>$dumpFile#导出数据文件
if[[$?==0]];then
tarcvzf$GZDumpFile$dumpFile>>$eMailFile2>&1
echo"BackupFileName:$GZDumpFile">>$eMailFile
echo"DataBaseBackupSuccess">>$eMailFile
scp$GZDumpFile地址”:/Dir#传送备份文件到另一台计算机,需要做好ssh信任
rm-f$dumpFile#删除备份的文件
rm�Crf$databak_dir/daily/*#删除每天备份的文件
else
echo"DataBaseBackupFail!">>$emailFile
mail-s"DataBaseBackupFail"$eMail<$eMailFile#如果备份不成功发送邮件通知
fi
echo"--------------------------------------------------------">>$logFile
cat$eMailFile>>$logFile更多mysqldump的选项请查看mysqldump�Chelp每天增量备份的脚本,定义为每天4点10分时运行此文件,备份上一天4点10分之后到今天4点之前的数据
#vimysqldailybak.sh
#!/bin/bash
#Thisismysqlmysqldailybakscripts
#2009-08-20
#badboy
/usr/bin/mysqladminflush-logs#
user=bak
passwd=123456
database=cacti
daily_databak_dir=$databak_dir/daily#备份目录,需要创建
eMailFile=$daily_databak_dir/email.txt
DATE=`date+%Y%m%d`
logFile=$daily_databak_dir/mysql$DATE.log
echo"">$eMailFile
echo"---------------------------------">>$eMailFile
echo$(date+"%y-%m-%d%H:%M:%S")>>$eMailFile
echo"---------------------------------">>$eMailFile
TIME=$(date"-d10dayago"+%Y%m%d%H%M%S)
StartTime=$(date"-d1dayago"+"%Y-%m-%d%H:%M:%S")
echo“Delete10daysbeforethelog”>>$eMailFile
mysql-u$user-p"$passwd"-e"purgemasterlogsbefore${TIME}"&&echo"delete10daysbeforelog"|tee-a$eMailFile#删除10天前的2进制文件
filename=/data/`cat/data/mysql-bin.index|awk-F"/"'{print$2}'`#2进制文件
foriin$filename
do
echo"$StartTimestartbackupbinlog">>$eMailFile
mysqlbinlog-u$user-p$passwd-d$batabase--start-datetime="$StartTime"$i>>$daily_databak_dir/daily$DATE|tee-a$eMailFile
done
if[$?=0]
then
cd$daily_databak_dir
tar-zcvf$daily_databak_dir/$database$DATE.tar.gzdaily$DATE>>/dev/null2>&1
#scp$daily_databak_dir/$database$DATE.tar.gz地址”:/Dir#传送备份文件到另一台计算机,需要做好ssh信任
echo"dailybackupsucceed">>$eMailFile
else
echo"dailybackupfail">>$eMailFile
mail-s"MySQLBackup"$eMail<$eMailFile#备份失败之后发送邮件通知
fi
cat$eMailFile>$logFile
添加可执行的权限
#chmod755/scripts/mysql_full_bak.sh/scripts/mysqldailybak.sh加到crontab里面让脚本自动执行,如果有专门用于备份的服务器,可以利用ssh认证、scp命令,自动发送到另一台服务器上,保证数据的安全。可以参看 rsync参数详解、利用ssh、rsync实现数据的定时同步#su�Cbak#crontab�Ce104**1-6/scripts/mysqldailybak.sh#礼拜一到礼拜六运行每天备份脚本
104**0/scripts/mysql_full_bak.sh#礼拜天执行全备份的脚本如果想把备份之后的数据文件,传送到另一台服务器上,做好ssh信任之后把脚本中红色的哪行注释去掉就行。需要更多scp的资料请查看scp--help本人对shell也不是很懂,如果里面有错误的地方,希望指正。谢谢#vibackup_mysql.sh#!/bin/bashbackup_dir=/backup/databak#备份文件放置目录
backup_target_dir=/backup/db
backup_logs_dir=/backup/logs#备份日志目录
db=bcmediaDATE=$(date+%Y%m%d)
#得到10天前的日期
ccDATE=$(date"-d10dayago"+%Y%m%d)echo"开始复制数据表">>$backup_logs_dir/$db$DATE
echo"-----------`date+"%Y-%m-%d%H:%M:%S"`--------------------">>$backup_logs_dir/$db$DATEcp-R/data/$db$backup_target_dir/#mysql数据库的数据目录为/dataecho"开始压缩数据表">>$backup_logs_dir/$db$DATE
echo"------------------------">>$backup_logs_dir/$db$DATEcd$backup_target_dirtar-zcvf$backup_dir/db$DATE.tar.gz$db/>>$backup_logs_dir/$db$DATEif[$?-eq0]
then
echo"backupsucceed">>$backup_logs_dir/$db$DATE
else
echo"backupfail">>$backup_logs_dir/$db$DATE
fiecho"开始删除原数据表">>$backup_logs_dir/$db$DATEecho"-----------------------">>$backup_logs_dir/$db$DATErm-rf$backup_target_dir/*&&echo“删除原数据表”>>$backup_logs_dir/$db$DATEecho"删除10天前数据">>$backup_logs_dir/$db$DATEif[-e$backup_dir/db$ccDATE.tar.gz]
then
rm-rf$backup_dir/db$ccDATE.tar.gz
echo"Delete$backup_dir/db$ccDATE.tar.gzsucceed">>$backup_logs_dir/$db$DATE
else
echo"Notfound$backup_dir/db$ccDATE.tar.gzfile">>$backup_logs_dir/$db$DATE
fi
if[-e$backup_logs_dir/$db$ccDATE]
then
rm-rf$backup_logs_dir/$db$ccDATE
echo"Delete$backup_logs_dir/$db$ccDATEsucceed">>$backup_logs_dir/$db$DATE
else
echo"Notfound$backup_logs_dir/$db$ccDATEfile">>$backup_logs_dir/$db$DATEfi