使用mysqldump 备份数据库(增备 全备)

http://colderboy.blog.51cto.com/485582/197614/
 
           mysqldump 是采用SQL级别的备份机制,它将数据表导成 SQL 脚本文件,在不同的 MySQL 版本之间升级时相对比较合适,这也是最常用的备份方法。关于mysqldump的更详细解释用/MysqlDir/bin/mysqldump –help 来查看详细的解释。
      我们使用的数据库备份完成之后有10个G如果每天都做一次全备,不方便,就一个星期做一次全备,一天做一次增量备份。为了不影响线上业务,实现在线备份,并且能增量备份,最好的办法就是采用主从复制机制(replication),在 slave 机器上做备份。详细的mysqlreplication请参看
mysql主主、主从复制详解
    一个星期一次的全备的脚本,脚本文件放在/scripts目录下,备份时需要一些目录,注意需要手动创建。
 
#vi mysql_full_bak.sh
#!/bin/bash
# This is mysql mysqlfullbak scripts
#2009-08-20
#badboy
user=bak   
passwd=123456
databak_dir=/backup/cacti   #备份的目录
eMailFile=$databak_dir/email.txt
eMail=leezhenhua17@163.com
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
  tar cvzf $GZDumpFile $dumpFile >> $eMailFile 2>&1
  echo "BackupFileName:$GZDumpFile" >> $eMailFile
  echo "DataBase Backup Success" >> $eMailFile
  scp $GZDumpFile 
user@”ip
地址”:/Dir   #传送备份文件到另一台计算机,需要做好ssh信任
  rm -f $dumpFile           #删除备份的文件
  rm –rf $databak_dir/daily/*  #删除每天备份的文件
else
  echo "DataBase Backup Fail!" >> $emailFile
  mail -s " DataBase Backup Fail " $eMail < $eMailFile  #如果备份不成功发送邮件通知
fi
echo "--------------------------------------------------------" >> $logFile
cat $eMailFile >> $logFile
更多mysqldump的选项请查看mysqldump –help
 
每天增量备份的脚本,定义为每天4点10分时运行此文件,备份上一天4点10分之后到今天4点之前的数据

#vi mysqldailybak.sh
#!/bin/bash
# This is mysql mysqldailybak scripts
# 2009-08-20
# badboy
/usr/bin/mysqladmin flush-logs   #
user=bak
passwd=123456
database=cacti
daily_databak_dir=$databak_dir/daily  #备份目录,需要创建
eMailFile=$daily_databak_dir/email.txt
eMail=leezhenhua17@163.com
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 "-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"$passwd" -e "purge master logs before ${TIME}" && echo "delete 10 days before log" |tee -a $eMailFile   #删除10天前的2进制文件
filename=/data/`cat /data/mysql-bin.index |awk -F "/" '{print $2}'`   # 2进制文件
for i in $filename
do
echo "$StartTime start backup binlog " >> $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.gz daily$DATE >>/dev/null 2>&1
 #scp $daily_databak_dir/$database$DATE.tar.gz 
user@”ip 地址”:/Dir  #传送备份文件到另一台计算机,需要做好ssh信任
 echo "daily backup succeed" >> $eMailFile
else 
 echo "daily backup fail" >> $eMailFile
 mail -s "MySQL Backup" $eMail < $eMailFile  #备份失败之后发送邮件通知
fi
cat $eMailFile > $logFile
添加可执行的权限                              
#chmod 755 /scripts/mysql_full_bak.sh /scripts/mysqldailybak.sh
加到crontab里面让脚本自动执行,如果有专门用于备份的服务器,可以利用ssh认证、scp命令,自动发送到另一台服务器上,保证数据的安全。可以参看rsync参数详解、利用ssh、rsync 实现数据的定时同步
 
 
#su –bak
 
#crontab –e
10 4 * * 1-6 /scripts/mysqldailybak.sh   #礼拜一到礼拜六运行每天备份脚本
10 4 * * 0 /scripts/mysql_full_bak.sh   #礼拜天执行全备份的脚本
如果想把备份之后的数据文件,传送到另一台服务器上,做好ssh信任之后把脚本中红色的哪行注释去掉就行。需要更多scp的资料请查看scp --help
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值