作/译者:叶金荣(Email: ),来源:http://imysql.cn,转载请注明作/译者和出处,并且不能用于商业用途,违者必究。
之前已经写过一篇关于 MySQL 备份和恢复 的文章,讲述了几种比较常见的备份和恢复策略。本文则是以一个实际的案例来讲解全量备份和增量备份。

一、前提条件

首先,需要设定一个同步的环境出来,可以在两个独立的主机或者同一个主机上实现,详细请参考MySQL做同步实例。接下来的备份工作就都是在Slave上实现了。
下面就拿一个实际的例子来讲解,MySQL Slave的版本为 5.0.27。
假定 datadir 为 /usr/local/mysql/data,备份文件存放目录为 /backup/mysql/,两种备份都由shell脚本来自动完成。

二、全量备份

全量备份的原理是停止slave之后,将数据刷新到磁盘中,然后直接拷贝数据文件。如果数据量相对较小,推荐使用mysqldump来做,较大的话,直接拷贝文件就更便捷了。
shell脚本文件名 backupmysql_fullly.sh:
#!/bin/sh
#
# created by yejr,2006/11/29
#
# 本脚本用于定期做全量备份,备份的对象是slave上的全部数据
# 每次备份之前都先执行"STOP SLAVE; FLUSH TABLES;",然后将
# 所有文件拷贝到备份目录下
#
#取得当前日期,作为备份目录名
today=`date +"%Y_%m_%d"`
#源目录
datadir=/usr/local/mysql/data
#目标目录
bkdir=/backup/mysql
today_bkdir=$bkdir/$today
today_full_bkdir=$today_bkdir/full_backup
#修改上级目录属性
chattr -i $bkdir
#判断目标目录是否已经存在
if [ ! -d $today_bkdir ] ; thenmkdir -p $today_bkdir
elsechattr -i $today_bkdir
fi
#执行 slave-stop && flush-logs,停止slave,并且刷新缓存内容到磁盘
mysqladmin -hlocalhost -uroot -ppasswd stop-slave
mysqladmin -hlocalhost -uroot -ppasswd flush-tables
cd $datadir
#将ibdata*以及其它需要备份的数据库目录拷贝到目标目录下
cp -rf ib* forum my.cnf mysql news yejr $today_full_bkdir/
#修改文件属主
chown -R nobody:nobody $bkdir
#执行 slave-start,启动slave
mysqladmin -hlocalhost -uroot -ppasswd start-slave
#删除过期文件
cd $bkdir
#找出6天前创建的目录
for d in `find . -type d -mtime +6 -maxdepth 1`
do#修改当前目录及其子目录属性,然后删除chattr -i $dchattr -i $d/full_backuprm -fr $d
done
#增加属性标志位
chattr +i $bkdir

三、增量备份

增量备份的原理是利用binlog的特性,定期刷新binlog,然后将旧的binlog备份起来,再加上以前的全量备份,就能在较短时间内得到当前的运行数据。
shell脚本文件名 backupmysql_hourly.sh:
#!/bin/sh
#
# created by yejr,2006/11/29
# 本脚本用于定期做增量备份,备份的对象是binlog
# 每次备份之前都先执行 flush-logs,然后将最近的binlog移动
# 到备份目录下
#
#取得当前日期,作为备份目录名
today=`date +"%Y_%m_%d"`
#源目录
datadir=/usr/local/mysql/data
#目标目录
bkdir=/backup/mysql
today_bkdir=$bkdir/$today
#修改上级目录属性
chattr -i $bkdir
#判断目标目录是否已经存在
if [ ! -d $today_bkdir ] ; thenmkdir -p $today_bkdir
elsechattr -i $today_bkdir
fi
#先执行"flush logs",创建出新的log文件
mysqladmin -hlocalhost -uroot -ppasswd flush-logs
#去的binlog文件总数,去掉最后一个以及binlog.index
total=`ls $logdir/bin_log.*|wc -l`
total=`expr $total - 2`
for f in `ls $logdir/bin_log.*|head -n $total`
do#备份日志文件bf=`basename $f`mv $f  $today_bkdir/$bf
done
#修改属主及目录属性
chown -R nobody:nobody $bkdir
chattr +i $bkdir
最后,在crontab中新增如下两行记录:
#从1-23时,每小时增量备份一次
0 1-23/1 * * * (/bin/sh /backup/mysql/backupmysql_hourly.sh \
>> /backup/mysql/backup.log &)
#周一、三、六、日凌晨0点全量备份
0 0 * * 0,1,3,6 (/bin/sh /backup/mysql/backupmysql_fullly.sh \
>> /backup/mysql/backup.log &)
如果觉得备份的频率太低了,可以自己适当调整crontab的频率。
以上脚本来自实际运行环境后稍作修改。
本文出自 “MySQL中文网”博客 http://www.imysql.cn/

再谈 MySQL 备份相关推荐

  1. 再谈MySQL JSON数据类型

    2019独角兽企业重金招聘Python工程师标准>>> 本文首发微信公众号<andyqian>.期待你的关注- 前言 眨眼间,有一小段时间没有更新文章了.唉,又懒了... ...

  2. 再谈MySQL全库备份

    简介 Part1:写在最前 在很早之前,我写过一个MySQL生产库全库备份脚本,今天有同事问我是不是要再加一个-R参数来备份存储过程,理由的话是由于mysqldump --help中 关于存储过程的默 ...

  3. mysql 恢复数据库乱码了_再谈MySQL数据库备份恢复和乱码问题

    在我转到wordpress之后第一个考虑的是它的数据库备份恢复问题,因为写bloger都知道,自己的blog记录的都是自己需要的宝贵的资料和文字,如果因为各种未知因素导致数据库崩溃或者空间商出了问题, ...

  4. mysql 数据库备份 乱码_再谈 MySQL 数据库备份恢复和乱码问题

    在我转到wordpress之后第一个考虑的是它的数据库备份恢复问题,因为写bloger都知道,自己的blog记录的都是自己需要的宝贵的资料和文字,如果因为各种未知因素导致数据库崩溃或者空间商出了问题, ...

  5. mysql锁机制为何设计如此复杂_再谈mysql锁机制及原理—锁的诠释

    加锁是实现数据库并发控制的一个非常重要的技术.当事务在对某个数据对象进行操作前,先向系统发出请求,对其加锁.加锁后事务就对该数据对象有了一定的控制,在该事务释放锁之前,其他的事务不能对此数据对象进行更 ...

  6. 浅谈MySQL数据库备份的几种方法

    mysql常见的备份方式有:mysqldump.mysqlhotcopy.BACKUP TABLE .SELECT INTO OUTFILE,又或者备份二进制日志(binlog),还可以是直接拷贝数据 ...

  7. pymysq向mysql写数据 为什么本地无法查看_从运维角度浅谈MySQL数据库优化,中小企业DBA必会...

    原文:http://www.enmotech.com/web/detail/1/712/1.html(复制链接,打开浏览器即可查看原文) 作者:搬砖游击队 一个成熟的数据库架构并不是一开始设计就具备高 ...

  8. 运维角度浅谈MySQL数据库优化(转自:2018-03-10 李振良 JAVA高级架构)

    一个成熟的数据库架构并不是一开始设计就具备高可用.高伸缩等特性的,它是随着用户量的增加,基础架构才逐渐完善.这篇博文主要谈MySQL数据库发展周期中所面临的问题及优化方案,暂且抛开前端应用不说,大致分 ...

  9. 从运维角度浅谈MySQL数据库优化

    一个成熟的数据库架构并不是一开始设计就具备高可用.高伸缩等特性的,它是随着用户量的增加,基础架构才逐渐完善.这篇博文主要谈MySQL数据库发展周期中所面临的问题及优化方案,暂且抛开前端应用不说,大致分 ...

最新文章

  1. iOS网络传输Delegate不被触发的本质原因
  2. 让你的应用程序支持高对比度模式
  3. BUUCTF--[GWCTF 2019]re3学习记录
  4. elxel表格纸张尺寸_印刷设计必懂知识:印刷纸张类型介绍
  5. Maven配置阿里镜像仓库
  6. 在coursera上有哪些值得推荐的课程
  7. Jquery函数大全 - 案例说明
  8. 【opencv】opencv在图片、视频嵌中英文字符的方法
  9. css 百分比 怎么固定正方形_web前端入门到实战:一次搞懂CSS字体单位:px、em、rem和%
  10. j2ee,ajax中文乱码解决方法。。
  11. Spring的9种设计模式(三)总结
  12. NATAPP使用笔记02
  13. 获得碳中和认证的六个步骤
  14. android体脂代码,该减肥了吗?教你用手机App测量体脂率
  15. 极大似然估计和最大似然估计定义
  16. 山东理工大学oj打字速度测试
  17. STM32 CAN通讯过滤器使用总结及代码分析
  18. JAVA名字正则表达式(包含新疆姓名)
  19. android实现vr 功能,VR模式成亮点:属于Android N的10大新功能
  20. Spring5基础知识

热门文章

  1. 毕啸南专栏 | 对话姚星:腾讯有后来居上的传统,我们的战略是全民AI
  2. 阿里巴巴的AI革命 | 4天云栖大会干货总结
  3. Item-Based Collaborative Recommender System
  4. 在树莓派上编译安装golang环境
  5. 如果$.ajax函数迟迟得不到响应,那么最有可能出错的地方是请求参数写错了
  6. Ubuntu:高效工作环境搭建
  7. ANT安装与测试和简明教程
  8. 本机找不到workstation 和 Computer Browser服务
  9. ubuntu8.04 升级到8.10后,apache2 不能用的解决办法
  10. 全网最简单的k8s User JWT token管理器