Mysql数据备份与mysqldump增量备份.doc

上传人:人*** 文档编号:544214647 上传时间:2023-11-08 格式:DOC 页数:5 大小:45KB
返回 下载 相关 举报
Mysql数据备份与mysqldump增量备份.doc_第1页
第1页 / 共5页
Mysql数据备份与mysqldump增量备份.doc_第2页
第2页 / 共5页
Mysql数据备份与mysqldump增量备份.doc_第3页
第3页 / 共5页
Mysql数据备份与mysqldump增量备份.doc_第4页
第4页 / 共5页
Mysql数据备份与mysqldump增量备份.doc_第5页
第5页 / 共5页
亲,该文档总共5页,全部预览完了,如果喜欢就下载吧!
资源描述

《Mysql数据备份与mysqldump增量备份.doc》由会员分享,可在线阅读,更多相关《Mysql数据备份与mysqldump增量备份.doc(5页珍藏版)》请在金锄头文库上搜索。

1、Mysql数据备份与mysqldump增量备份 在数据库表丢失或损坏的情况下,备份你的数据库是很重要的。如果发生系统崩溃,你肯定想能够将你的表尽可能丢失最少的数据恢复到崩溃发生时的状态。本文主要对MyISAM表做备份恢复。备份策略一:直接拷贝数据库文件备份策略二:使用mysqldump备份数据库(一个星期全备一次,每天增量备份)一、直接拷贝数据文件直接拷贝数据文件最为直接、快速、方便,但缺点是基本上不能实现增量备份。为了保证数据的一致性,需要在备份文件前,执行以下 SQL 语句:FLUSH TABLES WITH READ LOCK;也就是把内存中的数据都刷新到磁盘中,同时锁定数据表,以保证拷

2、贝过程中不会有新的数据写入。这种方法备份出来的数据恢复也很简单,直接拷贝回原来的数据库目录下即可。 为了方便的拷贝出数据文件,我写了一个脚本让其每天运行一次做备份。在/目录下建一个目录用来放置脚本文件,#mkdir /scripts创建一个备份数据库的一个脚本文件#vi backup_mysql.sh #!/bin/bashbackup_dir=/backup/databak #备份文件放置目录backup_target_dir=/backup/dbbackup_logs_dir=/backup/logs #备份日志目录db=bcmediaDATE=$(date +%Y%m%d) #得到10天

3、前的日期ccDATE=$(date -d 10 day ago +%Y%m%d)echo 开始复制数据表 $backup_logs_dir/$db$DATEecho -date +%Y-%m-%d %H:%M:%S- $backup_logs_dir/$db$DATEcp -R /data/$db $backup_target_dir/ #mysql数据库的数据目录为/dataecho 开始压缩数据表 $backup_logs_dir/$db$DATEecho - $backup_logs_dir/$db$DATEcd $backup_target_dirtar -zcvf $backup_d

4、ir/db$DATE.tar.gz $db/ $backup_logs_dir/$db$DATEif $? -eq 0 thenecho backup succeed $backup_logs_dir/$db$DATEelseecho backup fail $backup_logs_dir/$db$DATEfiecho 开始删除原数据表 $backup_logs_dir/$db$DATEecho - $backup_logs_dir/$db$DATErm -rf $backup_target_dir/* & echo “删除原数据表” $backup_logs_dir/$db$DATEech

5、o 删除10天前数据 $backup_logs_dir/$db$DATEif -e $backup_dir/db$ccDATE.tar.gz thenrm -rf $backup_dir/db$ccDATE.tar.gzecho Delete $backup_dir/db$ccDATE.tar.gz succeed $backup_logs_dir/$db$DATEelseecho Not found $backup_dir/db$ccDATE.tar.gz file $backup_logs_dir/$db$DATEfiif -e $backup_logs_dir/$db$ccDATE th

6、enrm -rf $backup_logs_dir/$db$ccDATEecho Delete $backup_logs_dir/$db$ccDATE succeed $backup_logs_dir/$db$DATEelseecho Not found $backup_logs_dir/$db$ccDATE file $backup_logs_dir/$db$DATEfi保存退出并添加可执行的权限#chmod 755 backup_mysql.sh让脚本每天执行一次,每天备份一次数据库,在crontab 里面添加一行Crontab e10 4 * * * /scripts/ backup_m

7、ysql.sh #每天4点10分运行脚本备份数据库 还原数据库的时候只要把备份出的文件拷贝到数据库放置数据的目录下,修改权限。重启下数据库就完成了恢复了。二、使用mysqldump备份数据库 mysqldump 是采用SQL级别的备份机制,它将数据表导成 SQL 脚本文件,在不同的 MySQL 版本之间升级时相对比较合适,这也是最常用的备份方法。关于mysqldump的更详细解释用/MysqlDir/bin/mysqldump help 来查看详细的解释。 我们使用的数据库备份完成之后有10个G如果每天都做一次全备,不方便,就一个星期做一次全备,一天做一次增量备份。为了不影响线上业务,实现在线

8、备份,并且能增量备份,最好的办法就是采用主从复制机制(replication),在 slave 机器上做备份。详细的mysqlreplication请参看mysql主主、主从复制详解 一个星期一次的全备的脚本,脚本文件放在/scripts目录下,备份时需要一些目录,注意需要手动创建。#vi mysql_full_bak.sh#!/bin/bash# This is mysql mysqlfullbak scripts#2009-08-20#badboyuser=bak passwd=123456databak_dir=/backup/cacti #备份的目录eMailFile=$databak

9、_dir/email.txteMail=DATE=date +%Y%m%d logFile=$databak_dir/logs/mysql$DATE.logdatabase=cactiecho $eMailFileecho - $eMailFileecho $(date +%y-%m-%d %H:%M:%S) $eMailFilecd /datadumpFile=$database$DATE.sqlGZDumpFile=$database$DATE.tar.gzoptions=-u$user -p$passwd -opt -extended-insert=false -triggers=fal

10、se -R -hex-blob -flush-logs -delete-master-logs -B $databasemysqldump $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信任 r

11、m -f $dumpFile #删除备份的文件 rm rf $databak_dir/daily/* #删除每天备份的文件else echo DataBase Backup Fail! $emailFile mail -s DataBase Backup Fail $eMail $logFilecat $eMailFile $logFile更多mysqldump的选项请查看mysqldump help每天增量备份的脚本,定义为每天4点10分时运行此文件,备份上一天4点10分之后到今天4点之前的数据#vi mysqldailybak.sh#!/bin/bash# This is mysql my

12、sqldailybak scripts# 2009-08-20# badboy/usr/bin/mysqladmin flush-logs #user=bakpasswd=123456database=cactidaily_databak_dir=$databak_dir/daily #备份目录,需要创建eMailFile=$daily_databak_dir/email.txteMail=DATE=date +%Y%m%d logFile=$daily_databak_dir/mysql$DATE.logecho $eMailFileecho - $eMailFileecho $(date

13、+%y-%m-%d %H:%M:%S) $eMailFileecho - $eMailFileTIME=$(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 ” $eMailFilemysql -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 $filenamedoecho $StartTime start backup binlog $eMailFilemysqlbinlog -u$user -p$passwd -d $batabase -start-datetime=$StartTime $i $daily_databa

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 科普知识

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号